鱼C论坛

 找回密码
 立即注册
查看: 1602|回复: 2

斐波那契数列的兔子迭代算法逻辑怎么理解?

[复制链接]
发表于 2019-4-5 15:02:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
> 求大佬解下题,万分感谢!

def fab(n):
    n1 = 1
    n2 = 1  
    n3 = 1  # 默认初始值先为1,这里也不太明白为啥要先预设 n3 = 1
    if n < 1:
        print('输入有误!')
        return -1
    while (n - 2) > 0:  #搞不太明白为什么 这里是 n-2 呢?n-1 也可以吧? 只要值> 0就会进入到循环
        n3 = n2+n1
        n1 = n2
        n2 = n3
        n -= 1
    return n3
result = fab(20)
if result != -1:
    print('总共有 %d 对小兔崽子'% result)
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-4-5 15:06:30 | 显示全部楼层
总归就一句话: 第一个月和第二个月的兔子数为1,此后每个月的兔子数等于前两个月兔子数之和。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-5 15:48:07 | 显示全部楼层
# 默认初始值先为1,这里也不太明白为啥要先预设 n3 = 1
-----为了使n为1和2时输出1,先预设n3 = 1
#搞不太明白为什么 这里是 n-2 呢?n-1 也可以吧? 只要值> 0就会进入到循环
-----控制循环次数,例如n为3,则仅循环1次,得到1+1,以此类推。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-1-15 02:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表