Python-汉诺塔

目标:把A柱子上的N个盘子移动到C柱子

递归的思想就是把这个目标分解成三个子目标

子目标1:将前n-1个盘子从a移动到b上

子目标2:将最底下的最后一个盘子从a移动到c上

子目标3:将b上的n-1个盘子移动到c上

然后每个子目标又是一次独立的汉诺塔游戏,也就可以继续分解目标直到N为1

def move(n, a, b, c):
    if n == 1:
        print(a, '-->', c)
    else:
        move(n-1, a, c, b)# 子目标1
        move(1, a, b, c)# 子目标2
        move(n-1, b, a, c)# 子目标3
n = input('enter the number:')
move(int(n), 'A', 'B', 'C')
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 昨天看廖雪峰的Python教程,看到了递归函数,具体的递归函数看他讲的就可以,最好自己好好研究一下递归函数是干啥的...
    oh_flying阅读 2,202评论 2 2
  • 一、问题描述及算法步骤 汉诺塔问题的大意是有三根柱子a, b, c,现在a柱有N个盘子从下往上尺寸递减排列,要求:...
    肖尔子阅读 1,201评论 0 0
  • 汉诺塔含义: 汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石...
    kevin282阅读 584评论 0 0
  • 汉诺塔的实现,是一个典型的递归问题,当然越是复杂的递归问题越是考验人的抽象思维; 哈哈哈,言归正传,汉诺塔问题如下...
    跟我去北方吧阅读 413评论 0 1
  • 作为一名python小白,在初学python的这几日遇到了一个还算有趣的问题,就是汉诺塔移动路径的打印,在这...
    Ano_onA阅读 291评论 0 0