递归之斐波那契数列java的3种方法

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

递归之斐波那契数列java的3种⽅法
本⽂实例为⼤家分享了java递归之斐波那契数列的具体代码,供⼤家参考,具体内容如下
第⼀种、普通写法
public class Demo {
public static void main(String[] args) {
int num1 = 1;
int num2 = 1;
int num3 = 0;
System.out.println(num1);
System.out.println(num2);
for (int i = 1; i < 10; i++) {
num3 = num1 + num2;
num1 = num2;
num2 = num3;
System.out.println(num3);
}
}
}
第⼆种、数组形式递归的写法
public class DIGUI1 {
public static void main(String[] args) {
int []arr=new int[20];
arr[1]=1;
arr[2]=1;
System.out.print(" "+arr[1]);
System.out.print(" "+arr[2]);
for(int i=3;i<20;i++){
arr[i]=arr[i-1]+arr[i-2];
System.out.print(" "+arr[i]);
}
}
}
第三种、递归形式的写法
public class Demo {
public static int f(int n) throws Exception {
if(n==0){
throw new Exception("参数错误!");
}
if (n == 1 || n == 2) {
return 1;
} else {
return f(n-1)+f(n-2);//⾃⼰调⽤⾃⼰
}
}
public static void main(String[] args) throws Exception {
for (int i = 1; i <=10; i++) {
System.out.print(f(i)+" ");
}
}
}
⽤递归最⼤的问题就是效率问题了,但是有的程序必须⽤递归写才可以写出来。

例如著名的汉若塔问题,如果有谁可以⽤其他⽅式写出来我服。

以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

相关文档
最新文档