汉诺塔之递归学习

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了汉诺塔之递归学习相关的知识,希望对你有一定的参考价值。

汉诺塔问题:

问题描述引自:http://www.cnblogs.com/antineutrino/p/3334540.html

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

技术分享

 

思维导图:

 

技术分享

程序代码:

 1 #汉诺塔
 2 def move(n,start=A,target=C):
 3     pos = set([A, B, C])
 4     if n==1:
 5         print(move %s to %s % (start, target))
 6     else:
 7         cur = set([start, target])
 8         mid=pos.difference(cur).pop()
 9         move(n - 1, start, mid)
10         print(move %s to %s % (start, target))
11         move(n - 1, mid, target)
12 
13 move(5)

输出:

 1 move A to C
 2 move A to B
 3 move C to B
 4 move A to C
 5 move B to A
 6 move B to C
 7 move A to C
 8 move A to B
 9 move C to B
10 move C to A
11 move B to A
12 move C to B
13 move A to C
14 move A to B
15 move C to B
16 move A to C
17 move B to A
18 move B to C
19 move A to C
20 move B to A
21 move C to B
22 move C to A
23 move B to A
24 move B to C
25 move A to C
26 move A to B
27 move C to B
28 move A to C
29 move B to A
30 move B to C
31 move A to C

 

以上是关于汉诺塔之递归学习的主要内容,如果未能解决你的问题,请参考以下文章

递归的学习(计算行列式汉诺塔问题)

用类比方式学习编程中函数递归(个人理解仅供参考)(内含汉诺塔问题的求解)

汉诺塔递归

递归_汉诺塔问题

Java学习:递归问题(举例:汉诺塔问题)。

python的递归算法学习:汉诺塔递归算法