鱼C论坛

 找回密码
 立即注册
查看: 1457|回复: 6

汉诺塔移动步骤用递归算法实现

[复制链接]
发表于 2018-4-6 18:35:47 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 HenryZhang 于 2018-4-6 21:43 编辑

在第24课,老师讲的汉诺塔步骤代码如下:
----------------------------------------------------------------------------
def hanoi(n, x, y, z):
    if n == 1:
        print(x, ' --> ', z)
    else:
        hanoi(n-1, x, z, y) # 将前n-1个盘子从x移动到y上    -     语句1
        print(x, ' --> ', z) # 将最底下的最后一个盘子从x移动到z上     -  语句2
        hanoi(n-1, y, x, z) # 将y上的n-1个盘子移动到z上    -   语句3

n = int(input('请输入汉诺塔的层数:'))
hanoi(n, 'X', 'Y', 'Z')
-------------------------------------------------------------------------------

虽然老师在视频也讲解了,而且也在代码上注释了,不过作为初学者的我,还是一头雾水,希望大神能帮帮我这个新手小白:
1. 对于这个递归代码的执行顺序问题,首先假设n=5开始执行代码,执行到第二行显然n=5而不等于1,所以往下执行else,在else里面有三个语句,这时候我就蒙了:
问题1:我想问问的是到第一个else开始,是调用执行hanoi(n-1, x, z, y)语句1(这个时候n变成4了)完后再继续执行调用语句1,直到n变成1的时候,再执行主语句下(n等于5的时候)的语句2 print(x, ' --> ', z) 吗? 还是什么顺序啊,如果是先一直调用执行语句1直到n变成1了,那语句3执行的时候,是不是直接就是执行n等于1的情况了啊。这个执行调用顺序我完全蒙了。

2,对于语句1和语句3,比如语句1,为啥把z和y顺序换一下,你就能实现指示从x移动到y上啊,所有的print语句都是写的(x, ' --> ', z)啊,怎么最后能显示出来x->y或者y->z呢 ?对于这个三个参数的位置,还有哪个xyz是参数,哪个xyz是里面赋的值有点彻底混乱了。。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-6 18:37:15 | 显示全部楼层
n从来没变过,只是用n减去几往里代
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-6 22:20:33 | 显示全部楼层

回帖奖励 +2 鱼币

你的问题正好我也想问,希望哪位大大能解答下
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-6 23:27:56 | 显示全部楼层
难道论坛里真的能解释清楚的人没有?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-6 23:49:23 | 显示全部楼层
迭代是一层层往下探索然后到终止的地方也就是N=1然后不断返回值,如果没有终止就会不断的迭代。。。我也是初学互相讨论
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-6 23:50:15 | 显示全部楼层
但是在N不会改变因为局部函数和全局变量的区别
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-7 09:05:28 | 显示全部楼层
似乎i明白了一点
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-26 22:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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