米多sir 2022-05-10 09:16 采纳率: 100%
浏览 37
已结题

python关于斐波那契数列的实现,举例计算小兔子的数量,用迭代的方法没搞明白

python关于斐波那契数列的实现,举例计算小兔子繁衍的数量,第一个月数量为1,第二个月数量为1,第三个月开始,当月数量等于前两个月数量之和,计算第20个月的时候一共多少只兔子。用递归的方法能想明白,但是用迭代的方法有些地方看不懂,请各位指教。

img

# 递归方法实现
def fab(n):
    if n < 1:
        print("输入有误")
        return -1

    if n == 1 or n == 2:
        return 1
    else:
        return fab(n-1) + fab(n-2)

result = fab(20)
if result != -1:
    print(result)

img

  • 写回答

2条回答 默认 最新

  • zlebhs 2022-05-10 09:40
    关注

    迭代就是,已知前两个月的数量求第三个月的数量,为了节省空间,前两个月的数量可以用2个变量来表示,每次只要修改一下这两个变量。自己debug一下就懂了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月25日
  • 已采纳回答 5月17日
  • 创建了问题 5月10日