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