Python初学笔记:递归解决汉诺塔问题

关于汉诺塔问题的描述,不再说明,网上有很多参考资料。这里只说明汉诺塔的解决思路。该问题采用递归方法,通过自底向上思想解决。

首先假设有N个圆盘,而前N-1个圆盘已经按照顺序在中间柱子上,则只需要将第N个圆盘从第1个柱子移动到第3个柱子上;然后再将前N-2个圆盘通过第3个柱子移动到第1个柱子上。。。


通过递归方法,可将这一过程描述成:

1. 将第1个柱子上的前N-1个圆盘通过第3个柱子移动到中间柱子(即第2个柱子)上;

2. 将第1个柱子上的第N个圆盘直接移动到第3个柱子上;

3. 将第2个柱子上的N-1个圆盘通过第1个柱子移动到第3个柱子上。


def moveTower(height, fromPole, toPole, withPole):
    if height >= 1:
        moveTower(height - 1, fromPole, withPole, toPole)
        moveDisk(fromPole, toPole)
        moveTower(height - 1, withPole, toPole, fromPole)

def moveDisk(fromPole, toPole):
    print "Moving: ", fromPole, '->', toPole


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值