鱼C论坛

 找回密码
 立即注册
查看: 646|回复: 1

[已解决]P24 递归小兔崽子例子里的问题

[复制链接]
发表于 2020-4-24 10:45:50 | 显示全部楼层 |阅读模式

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

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

x
def fab(n):
    if n < 1:
        print("输入有误!")
        return -1

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

result = fab(7)
if result != -1:
    print("总共有%d对小兔崽子诞生!" % result)


我想看看循环情况   else后面加了print(n)

这样可以吗?
当我N=7是  打印结果是
7
6
5
4
3
3
4
3
5
4
3
3
总共有13对小兔崽子诞生!

后面打印N的情况看不懂了
最佳答案
2020-4-24 11:23:03
这个很难么?自己在纸上划拉一下不就知道了。
每次递归中都会调用两次本函数,跟定是一层深入到底之后再进行第二次调用。
看下图,圈是调用顺序,数字是调用是的n值。每个3下面还有2和1,但是因为没有print,我就没写。
微信图片_20200424111951.jpg
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-24 11:23:03 | 显示全部楼层    本楼为最佳答案   
这个很难么?自己在纸上划拉一下不就知道了。
每次递归中都会调用两次本函数,跟定是一层深入到底之后再进行第二次调用。
看下图,圈是调用顺序,数字是调用是的n值。每个3下面还有2和1,但是因为没有print,我就没写。
微信图片_20200424111951.jpg
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 12:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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