目录
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柱的轨迹
输出结果
只要理解其中的原理,同样其他计算机语言也可以实现。重点是明白为什么可以用递归来解决这个问题。