编写一递归函数求斐波那契数列的前40项
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了编写一递归函数求斐波那契数列的前40项相关的知识,希望对你有一定的参考价值。
以下是使用递归函数来计算斐波那契数列的前40项的Python代码:pythonCopy code
def fibonacci(n): if n <= 1: return n else: return (fibonacci(n-1) + fibonacci(n-2)) # 计算前40项斐波那契数列 for i in range(40): print(fibonacci(i), end=" ")
在这个代码中,fibonacci(n) 函数使用递归方式来计算斐波那契数列的第 n 个数,如果 n 小于或等于 1,则直接返回 n;否则返回前两个斐波那契数的和。
在 for 循环中,我们通过迭代 0 到 39 来计算斐波那契数列的前 40 个数。在每次循环中,我们调用 fibonacci(i) 函数来计算第 i 个数,并使用 print() 函数将其打印到控制台。由于 print() 函数的 end 参数设置为一个空格,因此每个数字都会在同一行上打印。 参考技术A #include "stdio.h"
int Fib(int n)
if(n<=0)
printf("error input!");
return 0;
else if(n==1||n==2)return 1;
else return Fib(n-1)+Fib(n-2);
int main()
Fib(40);
system("pause");
return 0;
08《算法入门教程》递归算法之斐波那契数列
参考技术A本节内容是递归算法系列之一:斐波那契数列递归求解,主要介绍了斐波那契数列的定义,然后用递归的实现思想分析了一下斐波那契数列,最后给出了基于 Java 代码应用递归思想实现斐波那契数列的代码实现及简单讲解。
斐波那契数列(Fibonacci sequence),也称之为黄金分割数列,由意大利数学家列昂纳多・斐波那契(Leonardo Fibonacci)提出。斐波那契数列指的是这样的一个数列:1、1、2、3、5、8、13、21、34、……,这个数列从第 3 项开始,每一项都等于前面两项之和。在数学上,斐波那契数列可以被递推的方法定义如下:
斐波那契数列是数学上面一个经典的例子,并且在日常生活中有很多应用,他还与黄金分割有着密不可分的联系,而且当 n 趋向于无穷大时,前一项与后一项的比值越来越逼近黄金分割值 0.618。
在这一节中,我们就需要利用递归的思想去求解斐波那契数列,当给出一个斐波那契中第几项的数字,然后求解出对应的斐波那契数值。在之前,我们已经定义了递归算法的相关概念,并且明确了需要应用递归时候的三要素:
接下来,我们将利用递归的知识来解决斐波那契数列问题,明确在斐波那契数列求解问题中的递归三要素分别是什么。
例如,当我们求解斐波那契数列中的 F (5) 时,按照定义,我们有:
在说明斐波那契数列的递归描述之后,我们看看如何用 Java 代码来实现对斐波那契数列的计算。
运行结果如下:
代码中的第 4 行至第 8 行分别调用斐波那契数列计算函数,计算出斐波那契数列中对应 n=1,2,3,4,5 时斐波那契数列的取值,进行结果比较,判断斐波那契数列程序实现是否正确。代码中的第 12 行至第 20 行是斐波那契数列应用递归方法进行斐波那契数列的计算,按照递归的三要素进行计算处理。
本节主要介绍了用递归思想求解斐波那契数列,在学完本节课程之后,我们了解到了什么是斐波那契数列,并且将递归算法在斐波那契数列中进行了实际应用,需要掌握斐波那契数列的递归求解方法,并自己可以实现相关的代码实现,并清楚里面的每一步逻辑。
以上是关于编写一递归函数求斐波那契数列的前40项的主要内容,如果未能解决你的问题,请参考以下文章
编写一个程序,利用递归函数求斐波那契数列(0,1,1,2,3,5,8,13,21…… )前100项的和