鱼C论坛

 找回密码
 立即注册
查看: 4084|回复: 4

汉诺塔递归执行顺序

[复制链接]
发表于 2022-11-8 08:10:19 | 显示全部楼层
hanoi(n, x, y, z) 就是把 n 个圆盘从 x 上面挪到 z 上。
想实现这一个目标,我们可以分四步:
0. 如果 n = 1,直接把 n 从 x 上面挪到 z 上面就可以了。即为 x -> z。
1. n > 1 的时候,可以先把上面的 n-1 个圆盘挪到 y 上面,即为 hanoi(n-1, x, z, y)。
                          然后将最下面一个 圆盘挪到 z 上面,即为 x -> z。
                         最后把 y 上的 n-1 个圆盘挪到 z 上面就行了,即为 hanoi(n-1, y, x, z)。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-8 13:09:22 | 显示全部楼层
你干嘛哈哈哎哟 发表于 2022-11-8 13:00
这个我知道,但是那些形参对应的是位置还是名字我不太理解,X Y Z给到参数x y z 里面吗?然后递归里面的v ...

此时传进去的是 x y z 这三个 char 类型的字符,其中将 x 变量给 x 形参,z 变量给 y 形参,y 变量给 z 形参
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-27 09:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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