码迷,mamicode.com
首页 > 其他好文 > 详细

汉诺塔之递归学习

时间:2017-09-02 21:44:23      阅读:122      评论:0      收藏:0      [点我收藏+]

标签:传说   汉诺塔   分享   ges   png   www   http   str   nbsp   

汉诺塔问题:

问题描述引自: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

 

汉诺塔之递归学习

标签:传说   汉诺塔   分享   ges   png   www   http   str   nbsp   

原文地址:http://www.cnblogs.com/Franklin-Kite/p/7467933.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!