柱子汉诺塔问题回溯算法解法

xinyi1102 2022-06-06 15:28:54

 代码块

def hanoi(n, begin, mid, end):
    if n == 1:  #判断递归临界条件 当盘子数为1时 直接输出从开始位置到目标位置的柱子编号即可
        print(begin + "->" + end)
    else:
        hanoi(n - 1, begin, end, mid)   #先将n-1个盘子从开始柱子 移动到借助柱子
        print(begin + "->" + end)       #再输出第n个盘子的移动方向 从开始柱子移动到目标柱子
        hanoi(n - 1, mid, begin, end)   #最后将n-1个盘子从中间柱子 移动到目标柱子
    return

x = 'X'
y = 'Y'
z = 'Z'
n = 3

hanoi(n, x, y, z)

运行结果

 

...全文
131 回复 打赏 收藏 举报
写回复
回复
切换为时间正序
请发表友善的回复…
发表回复
相关推荐
发帖
江信Python研究社区

188

社区成员

一个专注于研究python语言的社区
软件工程 高校
社区管理员
  • 勤奋龙
  • 没有一分是自己的
  • Rye758
加入社区
帖子事件
编辑了帖子 (查看)
2022-06-06 15:31
创建了帖子
2022-06-06 15:28
社区公告
暂无公告