python学习032-----python之递归(三):用递归来实现汉诺塔

用递归实现汉诺塔
汉诺塔游戏:由三根柱子(X, Y, Z)和若干串在柱子上的大小不一的砝码组成。初始状态下,所有砝码
                     都按照上小下大的顺序排列在X柱上。
游 戏 目 标:将初始状态下的砝码,全部移动到Z柱上。
游 戏 规 则:一次只能移动一个砝码,且砝码必须严格按照上小下大的顺序进行移动。最终要将X柱
                     上的所有砝码都移动到Z柱上。
算 法 思 路:假设 X 柱上有n个砝码,要将这n个砝码都移动到Z上,需要:
                     1. 将前(n-1)个砝码先从 X 柱移动到 Y 柱上;
                     2. 再将最后一个砝码从 X 柱移动到 Z 柱上;
                     3. 最后将 Y 柱上的(n-1)个砝码移动到 Z 柱上。

                     其中:第2步最简单,移动一次就好,而第1步和第3步,实际上又是两次新的汉诺塔游
                     戏。那我们按照上面的思路对第1和第3步进行分解,得到如下步骤:
                    1的分解:
                                1> 将前(n-2)个砝码先从 X 柱移动到 Z 柱上;
                                2> 再将最后一个砝码从 X 柱移动到 Y 柱上;
                                3> 最后将 Z 柱上的(n-2)个砝码移动到 Y 柱上。
                    2的分解:
                                1> 将前(n-2)个砝码先从 Y 柱移动到 X 柱上;
                                2> 再将最后一个砝码从 Y 柱移动到 Z 柱上;
                                3> 最后将 X 柱上的(n-2)个砝码移动到 Z 柱上。 

                    其中:1、2的分解中的2>是最简单的,只需要移动一步即可。
                                而1、2的分解中的1>、3>又成了4次新的汉诺塔游戏...
                                那么按照上面的思路,我们不断地进行分解,最终一定会
                                分解到如下的元操作上:(分解到最后变为两个砝码的移动)
                                A> 将 "柱1"上的第一个砝码移动到 "柱2" 上;
                                B> 将 "柱1" 上的最后一个砝码移动到 "柱3" 上;
                                C> 将 "柱2" 上的那个砝码移动到 "柱3" 上。
根据上面的递归分析思路,我们找出了汉诺塔的游戏的元操作,那么我们便可以写递归代码来实现汉诺塔游戏了:

def hanoi(n, x, y, z):     #n代表砝码数,x为起始柱,y为中间柱,z为目标柱
    if n ==1 :
        print(x, '----->', z)   #如果只移动一个,直接由起始柱到目标柱
    else:
        hanoi(n-1, x, z, y)   #若移动n个砝码,则先将前(n-1)个移动到中间柱上
        hanoi(1, x, y, z)      #再将最后一个砝码移动到目标柱上 (这里实际上就是:"print(x, '----->', z)")
        hanoi(n-1, y, x, z)  #最后将中间柱上的(n-1)个砝码移动到目标柱上

n = int(input('请输入汉诺塔的层数:'))  
hanoi(n, 'X', 'Y', 'Z')

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值