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

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日

悬赏问题

  • ¥15 怎么把512还原为520格式
  • ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
  • ¥15 求高通平台Softsim调试经验
  • ¥15 canal如何实现将mysql多张表(月表)采集入库到目标表中(一张表)?
  • ¥15 wpf ScrollViewer实现冻结左侧宽度w范围内的视图
  • ¥15 栅极驱动低侧烧毁MOSFET
  • ¥30 写segy数据时出错3
  • ¥100 linux下qt运行QCefView demo报错
  • ¥50 F1C100S下的红外解码IR_RX驱动问题
  • ¥20 基于matlab的航迹融合 航迹关联 航迹插补