鱼C论坛

 找回密码
 立即注册
查看: 2576|回复: 3

[已解决]关于汉诺塔函数的疑惑,求大佬解答

[复制链接]
发表于 2022-3-29 15:43:24 | 显示全部楼层 |阅读模式

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

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

x
def haoni(n,x,y,z):
        if n == 1:
                print(x,'->',z)
        else:
                haoni(n-1,x,z,y)
                print(x,'->',z)
                haoni(n-1,y,x,z)

n=int(input('层数:'))
haoni(n,'A','B','C')

课中的例子是n=3
在第二次执行的时候 此时返回的 x=B y=A z=C
为什么重新执行else之后,得出来的和课中给的不一样。在这里搞不明白了,有没有大佬解答一些

自己算的
haoni(2,B,A,C)
执行else:
haoni(1,B,CA)
课上的
haoni(1,A,B,C)
最佳答案
2022-3-29 17:23:16
你可以手动调试,看看你的是否正确的
层数:3
归1 n=1 x->z A -> C
归2 n=2 x->z A -> B
归1 n=1 x->z C -> B
归2 n=3 x->z A -> C
归1 n=1 x->z B -> A
归2 n=2 x->z B -> C
归1 n=1 x->z A -> C

def haoni(n, x, y, z):
    if n == 1:
        print(f"归1 n={n} x->z", x, '->', z)  # 归1
    else:
        haoni(n-1, x, z, y)  # 递1
        print(f"归2 n={n} x->z", x, '->', z)  # 归2
        haoni(n-1, y, x, z)  # 递2


n = int(input('层数:'))
haoni(n, 'A', 'B', 'C')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-29 17:23:16 | 显示全部楼层    本楼为最佳答案   
你可以手动调试,看看你的是否正确的
层数:3
归1 n=1 x->z A -> C
归2 n=2 x->z A -> B
归1 n=1 x->z C -> B
归2 n=3 x->z A -> C
归1 n=1 x->z B -> A
归2 n=2 x->z B -> C
归1 n=1 x->z A -> C

def haoni(n, x, y, z):
    if n == 1:
        print(f"归1 n={n} x->z", x, '->', z)  # 归1
    else:
        haoni(n-1, x, z, y)  # 递1
        print(f"归2 n={n} x->z", x, '->', z)  # 归2
        haoni(n-1, y, x, z)  # 递2


n = int(input('层数:'))
haoni(n, 'A', 'B', 'C')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-30 08:45:19 | 显示全部楼层
大马强 发表于 2022-3-29 17:23
你可以手动调试,看看你的是否正确的

谢谢大佬,琢磨了很久。目前懂了

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-30 10:09:00 | 显示全部楼层
不想学习能躺平 发表于 2022-3-30 08:45
谢谢大佬,琢磨了很久。目前懂了

给个最佳
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-28 03:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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