汉诺塔的递归实现,看完就懂了

对于要实现汉诺塔递归程序的同学,我相信有一部分同学还没有真正的玩过汉诺塔这个游戏,我建议你们现在手机随便哪个应用商店里下载一个汉诺塔游戏去玩一会,你了解了游戏的玩法之后,也更方便你去理解递归代码的逻辑。下面通过标准汉诺塔简单介绍一下这个游戏和玩法:有三个柱子,初始情况是在其中一个柱子上叠有 N 个盘子,盘子从下往上依次变小,在规定大盘子不能在比自己小的盘子的上方的情况下,将盘子从初始情况下的柱子上移到另外一个柱子上,且规定移动过程中一次只能移动一个盘子。起始柱:当前汉诺塔问题初始状态时所有碟子所在的
摘要由CSDN通过智能技术生成

对于要实现汉诺塔递归程序的同学,我相信有一部分同学还没有真正的玩过汉诺塔这个游戏,我建议先在手机应用商店下载一个汉诺塔游戏去感受一下,当了解了游戏的玩法之后,也更方便你去理解递归代码的逻辑。

下面通过标准汉诺塔简单介绍一下这个游戏和玩法:

有三个柱子,初始情况是在其中一个柱子上叠有 N 个碟子,碟子从下往上依次变小,在规定大碟子不能在比自己小的盘子的上方的情况下,将所有盘子从初始状态所在的柱子上移到另外一个柱子上,且规定移动过程中一次只能移动一个碟子


起始柱:当前汉诺塔问题初始状态时所有碟子所在的柱子。

目标柱:玩家想将所有碟子移动至此柱。

中介柱:除了起始柱和目标柱的另外一个柱子,在解决问题的过程中往往作为中转柱。


就是说,从这样( N = 3 时):
在这里插入图片描述

变成这样:
在这里插入图片描述

此时的问题就是:将三层汉诺塔从起始柱 A 移动到目标柱 C。

想将三层碟子从起始柱 A 移到目标柱 C ,肯定得经过红碟子从起始柱 A 移到目标柱 C 这个步骤,为了不违反规定只能将红盘子子上面的第一二层移动到中介柱 B ,才能保证红碟子的道路畅通,然后红碟子才能从起始柱 A 移到目标柱 C ,所以此时就有了第二个问题:将第一二层碟子移动到 B 来给第三层碟子让路(注意 :第一个问题的中介柱 B 发挥了他的中转作用变成了第二个问题的目标柱 B)。第二个问题解决之后红碟子的路就通了,将红碟子移动到 C, 再将 B 柱的两层碟子移动到 C,问题就解决了(三层碟子从 A柱 移动到 C柱)。
在这里插入图片描述

很明显要想完成第二个问题,肯定得经过第二层绿碟子从起始柱 A 移到此时的目标柱 B这

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

有裂痕的石头

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值