#1.label标签进行goto操作
示例代码如下:
outer:for(int i=100;i<150;i++)
{
for(int j = 2;j<i/2;j++)
{
if(i%j==0){
continue outer;
}
}
System.out.print(i+"");
}
这种循环结构是通过label标签进行递归循环操作,continue语句被执行时,返回到对应的outer label标签进行执行。
#2.如何打印一个三角形或其他对称阵
示例代码如下:
for(int i = 1;i<=5;i++){
for(int j=5;j>=i;j--){
System.out.print(" ");
}
for(int j=1;j<=i;j++){
System.out.print("*");
}
for(int j=1;j<i;j++){
System.out.print("");
}
}
注:考虑此类问题时,思路一定要开阔,可以联系数据结构中的存储压缩矩阵的方法,先考虑对称,再考虑斜对角,然后把打印或者存储拆分为一个个的可循环的步骤,用代码写出
#3.方法
Java方法是语句的集合,它们在一起执行一个功能。
方法是解决一类问题的步骤的有序集合;
方法包含于类或对象中;
方法在程序中被创建,在其他地方被引用;
设计方法的原则 :方法的本意是功能块,就是实现某个功能的语句块的集合,我们设计方法的时候,最好保持方法的原子性,即最小不可再分割化。一个方法只完成一个功能,有利于我们后期的拓展。
方法的定义:类似于其他语言的函数,是一段用来完成特定功能的代码片段,一般情况下,定义一个方法包含以下语法:
示例代码:
修饰符 返回值类型 方法名(参数类型 参数名){
。。。
方法体
。。。
return 返回值;
}
包含一个方法头包含一个方法体
修饰符:可选的,告诉编译器如何调用方法,定义了方法的访问类型。
返回值类型:方法可能会有返回值,returnValueType是方法返回值的数据类型,有些方法执行所需的操作,但没有返回值,这种情况下,returnValueType是关键词void。
方法名:是方法的实际名称、方法名和参数表共同构成方法签名。
参数类型:参数像是一个占位符,当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,方法可以不包含任何参数。
形式参数:在方法被调用时用于接收外界输入的数据
实参:调用方法时实际传递的数据
注:可以理解为形式参数是一个抽象的的输入,用来统称所有输入的数据,实参是一个具体的进入方法内部参与操作,参与赋值,计算的值,可以联系操作系统中的寻址方式的直接寻址和间接寻址,直接寻址输入进去计算的值就一定是不会变得,而间接寻址找到的是一个数据地址,这个地址可以包含不同的数据。
#4.方法调用
调用方法:对象名.方法名(实参列表)
Java支持两种调用方法的方式,根据方法是否返回值来选择。
当方法返回一个值的时候,方法调用通常被当做一个值。
示例代码:
int lager = max(30,40);
如果方法没有返回值,则方法调用时一定是一条语句。
#5.方法的重载
重载就是在一个类中,有相同方法名,但形式参数不一样的函数。可以理解为只是方法名称相同,但并不是一个方法,因为计算机在执行方法时,会通过方法名 参数 返回值来区分方法,所以在计算机视角上看,它看到方法名相同,但传递的参数和返回值不一样,那它就是对第一个使用这个方法的方法的重载。
方法重载的原则:
方法名必须相同。
参数列表必须不同(个数不同、或类型不同、参数排列顺序不同等)。
方法的返回类型可以相同可以不同。
仅仅返回类型不同不足以成为方法重载。
实现理论:
方法名称相同时,编译器会根据调用方法的参数个数,参数类型等逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错。
#6.命令行传参
在public static void main(String args[]){}中,可以通过命令行的当时进行传参,将值传入args[]数组中,示例代码如下:
public class commandLine{
public static viod main(String args[]){
for(int i= 0;i<args.length;i++){
System.out.println("args["+i+"]:"+args[i]);
}
}
}
//调用时,可以选择系统的cmd界面或者idea的命令行界面,先使用Javac语句将Java文件编译为class文件,然后用java commandLine 要传入的参数1 要传入的参数2 。。。要传入的参数n
#7.可变参数
即使用省略号(...)来进行不定项参数定义,使用了省略号,此时先对传入参数进行判断,是否是无参数传入,有参数传入,则累计参数数量,进行依次输出。
一个方法只能指定一个可变参数,它必须是方法的最后一个参数,任何普通参数都必须在它之前声明。
示例代码如下:
public static void printmax( double...numbers){
if (numbers.length == 0)
{
System.out.println("no argsument passed!");
}
double result = number[0];
//排序算法
for (int i=1;i<number.length;i++){
if(numbers[i]>result){
result=numbers[i];
}
}
System.out.println("the Max value is"+result);
}
#8.递归
递归就是方法在运行的过程中自己调用了自己。
利用递归可以解决很多大型的问题,以空间换时间方法,提升工作效率,在思考acm时就可以想想这种方法,避免了重复运算,大大的减少了代码量,以一个有限的集合来定于对象无穷的集合。
递归由两个部分构成:
递归头:什么时候不调用自身方法,如果没有这个最底层的结束递归的语句,递归将会进入死循环。
递归体:什么时候调用自身。
示例代码如下:
int count(int a)
{
if(a==1){
return 1; //递归头
}
esle{
return a*count(a-1);递归体
}
}