鱼C论坛

 找回密码
 立即注册
查看: 2047|回复: 0

[技术交流] 递归函数之汉诺塔执行流程图解

[复制链接]
发表于 2020-3-13 13:08:49 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 yeahwsw 于 2020-3-13 15:36 编辑
def han(n,a="a",b="b",c="c"):
    if n==1:
        print(a,"――→",c)
    else:
        han(n-1,a,c,b)      #将a柱上面的n-1块移至b
        han(1,a,b,c)        #将a柱上的最后1块移至c     
        han(n-1,b,a,c)      #将b柱上面的n-1块移至b
han(4,a="a",b="b",c="c")
执行流程大致如下:不知道有没有错,只要函数中的n=1或者运算后等于1,则执行if后面的语句。
显示的是n=4的运行过程,太多也搞不过来。如有错误请指正。


                               
登录/注册后可看大图
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 18:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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