鱼C论坛

 找回密码
 立即注册
查看: 2500|回复: 5

汉诺塔这个程序有点看不懂

[复制链接]
发表于 2020-10-31 14:16:30 From FishC Mobile | 显示全部楼层 |阅读模式

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

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

x
Screenshot_20201031-140910.jpg 汉诺塔游戏不是每次只能移动一个吗  为什么注释上说将n-1个移动到y上
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-31 15:33:13 | 显示全部楼层
意思是接下来的目标就是把剩余的n-1个移动到y上,然后再目标是n-2个,一直递归到1个的时侯return
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-31 15:37:30 From FishC Mobile | 显示全部楼层
小甲鱼的铁粉 发表于 2020-10-31 15:33
意思是接下来的目标就是把剩余的n-1个移动到y上,然后再目标是n-2个,一直递归到1个的时侯return

那每一次递归  y和z都要换一次位置吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-31 15:45:54 | 显示全部楼层
小可爱. 发表于 2020-10-31 15:37
那每一次递归  y和z都要换一次位置吗

每次输出的是函数中的x->z,每次递归时传入函数的参数的顺序都会改变,改变的原则就是先把n-1个移动到中间的柱子hanoi(n-1, x, z, y),从x移动到y,把剩余的一个移动到最右边的print(x,"-->",z),再把n-1个移动到最右边hanoi(n-1,y,x,z),从y移动到x,所以调用递归函数时有位置,每次都有xyz之间的相互换位子
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-31 16:36:57 | 显示全部楼层
考虑三个的情况

A    B    C

1. A --> B 取最上面两个
2. A --> C 取最下面一个
3. B --> C 取刚刚移动到B的两个

现在有N个小方块,也要做同样的事情
很简单,把最下面的那个单独考虑就可以了。不明白的可以回复我们可以讨论
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-31 16:41:56 | 显示全部楼层
为啥从N=3开始考虑,因为N=3具有一般性
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-18 00:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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