当前位置: 首页 > 编程笔记 >

三种java编程方法实现斐波那契数列

卫念
2023-03-14
本文向大家介绍三种java编程方法实现斐波那契数列,包括了三种java编程方法实现斐波那契数列的使用技巧和注意事项,需要的朋友参考一下

题目要求:编写程序在控制台输出斐波那契数列前20项,每输出5个数换行

//java编程:三种方法实现斐波那契数列
//其一方法:

public class Demo2 { 
  // 定义三个变量方法 
  public static void main(String[] args) { 
    int a = 1, b = 1, c = 0; 
    System.out.println("斐波那契数列前20项为:"); 
    System.out.print(a + "\t" + b + "\t"); 
    //因为前面还有两个1、1 所以i<=18 
    for (int i = 1; i <= 18; i++) { 
      c = a + b; 
      a = b; 
      b = c; 
      System.out.print(c + "\t"); 
      if ((i + 2) % 5 == 0) 
        System.out.println(); 
    } 
  } 
 
} 

//java编程:三种方法实现斐波那契数列
//其二方法:

public class Demo3 { 
  // 定义数组方法 
  public static void main(String[] args) { 
    int arr[] = new int[20]; 
    arr[0] = arr[1] = 1; 
    for (int i = 2; i < arr.length; i++) { 
      arr[i] = arr[i - 1] + arr[i - 2]; 
    } 
    System.out.println("斐波那契数列的前20项如下所示:"); 
    for (int i = 0; i < arr.length; i++) { 
      if (i % 5 == 0) 
        System.out.println(); 
      System.out.print(arr[i] + "\t"); 
    } 
  } 
 
} 

//java编程:三种方法实现斐波那契数列
//其三方法:

public class Demo4 { 
  // 使用递归方法 
  private static int getFibo(int i) { 
    if (i == 1 || i == 2) 
      return 1; 
    else 
      return getFibo(i - 1) + getFibo(i - 2); 
  } 
 
  public static void main(String[] args) { 
    System.out.println("斐波那契数列的前20项为:"); 
    for (int j = 1; j <= 20; j++) { 
      System.out.print(getFibo(j) + "\t"); 
      if (j % 5 == 0) 
        System.out.println(); 
    } 
  } 
 
} 

这道兔子题的实质就是斐波那契数列: 有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?,现在从变量、数组、递归三个角度出发解决这个puzzle,当然还有其它的方法,同一道题用各种不同的思路去思考解决,也是对知识综合运用的锻炼吧。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 费波那契数列(意大利语:Successione di Fibonacci),又译费波拿契数、斐波那契数列、斐波那契数列、黄金分割数列。 在数学上,费波那契数列是以递归的方法来定义: F0 = 0 (n=0) F1 = 1 (n=1) Fn = F[n-1]+ F[n-2](n=>2) 关于Fibonacci的精彩解释,请看下列视频: TED-神奇的斐波那契数列 如果要查看文字解释,请

  • 本文向大家介绍Java递归实现斐波那契数列,包括了Java递归实现斐波那契数列的使用技巧和注意事项,需要的朋友参考一下 程序调用自身的编程技巧称为递归( recursion)。递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所

  • 主要内容:递归生成斐波那契数列,总结公元 1202 年,意大利数学家莱昂纳多·斐波那契提出了具备以下特征的数列: 前两个数的值分别为 0 、1 或者 1、1; 从第 3 个数字开始,它的值是前两个数字的和; 为了纪念他,人们将满足以上两个特征的数列称为斐波那契数列。 如下就是一个斐波那契数列: 1 1 2 3 5 8 13 21 34...... 下面的动画展示了斐波那契数列的生成过程: 图 1 斐波那契数列 很多编程题目要求我们输

  • 本文向大家介绍递归之斐波那契数列java的3种方法,包括了递归之斐波那契数列java的3种方法的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了java递归之斐波那契数列的具体代码,供大家参考,具体内容如下 第一种、普通写法 第二种、数组形式递归的写法 第三种、递归形式的写法 用递归最大的问题就是效率问题了,但是有的程序必须用递归写才可以写出来。例如著名的汉若塔问题,如果有谁可以用其他

  • 本文向大家介绍JS实现斐波那契数列的五种方式(小结),包括了JS实现斐波那契数列的五种方式(小结)的使用技巧和注意事项,需要的朋友参考一下 下面是五种实现斐波那契数列的方法 循环 普通递归 尾递归 闭包实现 到此这篇关于JS实现斐波那契数列的五种方式(小结)的文章就介绍到这了,更多相关JS 斐波那契数列内容请搜索呐喊教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持呐喊教程!

  • 题目链接 NowCoder 题目描述 求斐波那契数列的第 n 项,n <= 39。 <!--1}\end{array}\right." class="mathjax-pic"/> --> 解题思路 如果使用递归求解,会重复计算一些子问题。例如,计算 f(4) 需要计算 f(3) 和 f(2),计算 f(3) 需要计算 f(2) 和 f(1),可以看到 f(2) 被重复计算了。 递归是将一个问题划分