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

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)

运行结果

 

...全文
373 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

208

社区成员

发帖
与我相关
我的任务
社区描述
一个专注于研究软件新技术的社区
软件工程 高校
社区管理员
  • 勤奋龙
  • 没有一分是自己的
  • Rye758
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧