递归Recursion——Fibonacci

题目是构建一个Fibonacci数列

这是原来自己写的代码:
k = int(input("Which term? ")) #输入要寻找的数
count = 2 # 计数
next_num = 0 #原始的Fibonacci函数里的数
if int(k) <= 2: #当数是F1和F2的时候就直接print1 
    print(1)
else:
    while count <= k: #其他时候,进行循环,比如要找到Fibonacci的第五个数,则当count<5的时候,while 条件成立
        next_num = 2 + next_num  # 第三个数的为0+2,然后计数,循环
        count = count +1
    print(next_num)

这样子写的话,每一次的循环就是每一个数加上2,递归的关键在于找到递归的等价关键式。这里的关键式:f(n) = f(n-1) + f(n-2)

k = int(input("Which term? "))
current = 0
n_2 = 1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
非常好的问题!斐波那契数列是由0、1开始,后面的每一项都是前两项的和。所以斐波那契数列的前几项如下: 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144... 接下来,我会先讲解如何用递归实现斐波那契数列的第n项,然后再介绍如何用迭代实现。 递归实现 递归实现斐波那契数列的思路很简单:对于斐波那契数列的第n项,我们可以先求出第n-1和n-2项,然后将它们相加即可。而对于第n-1和n-2项,我们同样可以用同样的方式求出。 根据递归的思路,我们可以定义一个递归函数,代码如下: int fibonacci_recursion(int n) { if (n <= 0) return 0; else if (n == 1) return 1; else return fibonacci_recursion(n-1) + fibonacci_recursion(n-2); // 递归调用 } 上面的代码先判断了一下n的值是否小于等于0或等于1,这是为了避免递归陷入无限循环。如果n等于0,则返回0;如果n等于1,则返回1。否则,我们将递归调用fibonacci_recursion(n-1)和fibonacci_recursion(n-2),并将它们相加返回。 但是,这个递归实现有一个很明显的问题:当n比较大时,递归会变得非常的深,这会导致函数调用栈溢出。因此,我们需要用迭代来替代递归。 迭代实现 迭代实现斐波那契数列的思路与递归实现基本一致,只是用循环替代了递归。我们首先初始化前两项为0和1,并用循环依次计算出后面的每一项。 具体实现如下: int fibonacci_iteration(int n) { if (n <= 0) return 0; else if (n == 1) return 1; int a = 0, b = 1, c; for (int i = 2; i <= n; i++) { c = a + b; a = b; b = c; } return b; } 上面的代码中,我们先判断了一下n的值,如果n等于0,则返回0,如果n等于1,则返回1。然后,我们用a初始化为0,b初始化为1,依次计算出后面的每一项。具体实现如下: - 首先,我们将a和b的值相加,将结果赋值给变量c。 - 然后,将b的值赋给a,将c的值赋给b。 - 最后,当i>n时,返回变量b即可。 这个迭代实现的想法很简单,而且循环的次数只有n-1次,因此它是比递归实现更加高效的一种实现方法。 总结 斐波那契数列是一道经典的算法题,也是算法和程序设计中很重要的一个概念。我们用递归和迭代分别实现了斐波那契数列的第n项,递归实现简单,但会导致函数调用栈溢出;迭代实现思路相对复杂,但是效率更高,不会出现函数调用栈溢出的问题。我希望我的回答能够帮助你更好地理解斐波那契数列

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值