Python - 快速理解汉诺塔

目录

1、前言

2、游戏案例

3、发现规律

4、代码实现


1、前言

汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古老传说的。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。(来源百度百科)

2、游戏案例

已知A,B,C三根圆柱,且A柱上有自下而上,从大到小堆积的3个圆盘,需要将其移动到C柱上,

        条件1:每次只能移动一个圆盘

        条件2:小圆盘上面不能放置大圆盘

输出每次圆盘移动的轨迹(如 A柱 -> C柱, B柱 -> C柱)

3、发现规律

        仔细观察①④⑤⑧

可以发现 ① -> ④ 等同于汉诺塔2个圆盘的移动轨迹(此时可忽略蓝色圆盘,因为蓝色是最大的盘,因此满足汉诺塔的条件2:小圆盘上面不能放置大圆盘)。

        ① -> ④ 等价汉诺塔2个圆盘的移动轨迹,即 2个圆盘从A柱移动到B柱的轨迹

        ④ -> ⑤ 等价汉诺塔1个圆盘的移动轨迹,即 1个圆盘从A柱移动到C柱的轨迹

        ⑤ -> ⑧ 等价汉诺塔2个圆盘的移动轨迹,即 2个圆盘从B柱移动到C柱的轨迹

 我们还可以把红框内部看成一个整体,假设总共有n个圆盘需要移动,则红框内有(n - 1)个圆盘 

 可得

        ① -> ④ 等价汉诺塔(n - 1)个圆盘的移动轨迹,即 (n - 1)个圆盘从A柱移动到B柱的轨迹

        ④ -> ⑤ 等价汉诺塔1个圆盘的移动轨迹,即 1个圆盘从A柱移动到C柱的轨迹

        ⑤ -> ⑧ 等价汉诺塔(n - 1)个圆盘的移动轨迹,即 (n - 1)个圆盘从B柱移动到C柱的轨迹

可发现符合递归函数的性质,因此可以用递归函数来实现。

4、代码实现

# n 为移动圆盘的总数
# a 为圆盘当前所在的位置
# b 为闲置圆柱
# c 为圆盘目标移动位置

def move(n, a, b, c):
    if n == 1:
        print(a,'->',b)
    else:
        move(n-1, a, c, b)    # (n - 1)个圆盘从A柱移动到B柱的轨迹
        move(1, a, b, c)      # 1个圆盘从A柱移动到C柱的轨迹
        move(n-1, b, a, c)    # (n - 1)个圆盘从B柱移动到C柱的轨迹

move(3, A, B, C)    #计算3个圆盘从A柱移动到C柱的轨迹    

输出结果

 只要理解其中的原理,同样其他计算机语言也可以实现。重点是明白为什么可以用递归来解决这个问题。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值