本文主要是介绍兔子繁衍和最大公约数(Java版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 一、前言
- 二、兔子繁衍问题
- 三、求最大公约数
- 四、this()用法
一、前言
算法上机作业,本来用C语言写,但VScode一直抽风,最近学校在上Java,不妨换种语法写
目前感受:JavaSE的语法其实和C没啥区别,换汤不换药
二、兔子繁衍问题
1、问题
典型的斐波那契数列
1 、 1 、2 、 3 、 5 、8 、 13 、 21 、34…
2、解决
① 方法一
迭代关系式 y[ i ] = y[ i-1 ] + y[ i-2 ]
public class Rabit_1 {public static void main(String[] args) {int[] arr=new int[3];int i,j;System.out.println("请输入当前的月数");Scanner scanner=new Scanner(System.in);j=scanner.nextInt();arr[0]=arr[1]=1; //1,2月兔子个数为1System.out.println("arr[1] = "+arr[0]);System.out.println("arr[2] = "+arr[1]);for(i=2;i<j;i++){arr[2]=arr[1]+arr[0];System.out.println("arr["+(i+1)+"] = "+arr[2]);arr[0]=arr[1];arr[1]=arr[2];}}
}
② 方法二
迭代关系式
a = b+c; b = a+c; c = a+b;
public class Rabit2 {public static void main(String[] args) {int a=1,b=1,c,i;for(i=1;i<=4;i++){c=a+b;a=b+c;b=c+a; //输出的结果不完美System.out.print(a+" "+b+" "+c+" ");}}
}
③ 方法三
迭代关系式
a = a+b; b = a+b;
public class Rabit3 {public static void main(String[] args) {int i,a=1,b=1;System.out.print(a+" "+b+" ");for(i=1;i<=5;i++){a=a+b;b=a+b;System.out.print(a+" "+b+" ");}}
}
三、求最大公约数
1、方法一
穷举法
public class Gongyueshu_1 {public static void main(String[] args){int a,b,t;System.out.println("输入两个整数");Scanner scanner=new Scanner(System.in);a=scanner.nextInt();b=scanner.nextInt();t=a<b? a: b; //取ab中较小的数while(!(a%t==0&&b%t==0)){t--;}System.out.println(a+"和"+b+"的最大公约数为 "+t);}
}
2、方法二
辗转相除法
public class Gongyueshu_2 {public static void main(String[] args) {int a,b,r,a1,b1;System.out.println("请输入两个整数");Scanner scanner=new Scanner(System.in);a=scanner.nextInt();b=scanner.nextInt();a1=a;b1=b;while(b!=0){r=a%b;a=b;b=r;}System.out.println(a1+"和"+b1+"的最大公约数是 "+a);}
}
3、方法三
相减法
public class Gongyueshu3 {public static void main(String[] args) {Scanner scanner=new Scanner(System.in);int a,b;System.out.println("请输入两个整数");a=scanner.nextInt();b=scanner.nextInt();if(a==b) {System.out.println("最大公约数是:" + a);}else{while(a!=b){if(a>b)a=a-b;elseb=b-a;}System.out.println("最大公约数是:" + a);}}
}
四、this()用法
1、介绍
之前上课老师讲到this这个关键字的时候,this.变量名倒是讲清楚了
① 直接引用
this 指向当前对象本身
② 避免重复
形参与成员变量重复,用this区分
③ this( )
引用构造函数
this(参数):调用本类中另一种形式的构造函数(应该为构造函数中的第一条语句)。
2、代码
① Person类
② 主函数Main
这篇关于兔子繁衍和最大公约数(Java版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!