汉诺塔-python递归

汉诺塔-Python代码实现(递归)

python 复制代码
def hannoi(n: int, x: str, y: str, z: str):
    """ 汉诺塔 """
    if n == 1:  # 一块圆盘,直接移动到Z
        print(x, ' -> ', z)
    else:
        # 不为一块圆盘,先将n-1个圆盘,从X通过Z,移动到Y
        hannoi(n - 1, x, z, y)
        print(x, ' -> ', z)     # X上只剩一块,然后移动到Z
        hannoi(n - 1, y, x, z)  # 再将n-1块圆盘,从Y通过X移动到Z


if __name__ == '__main__':
    hannoi(4, 'X', 'Y', 'Z')

# X  ->  Y
# X  ->  Z
# Y  ->  Z
# X  ->  Y
# Z  ->  X
# Z  ->  Y
# X  ->  Y
# X  ->  Z
# Y  ->  Z
# Y  ->  X
# Z  ->  X
# Y  ->  Z
# X  ->  Y
# X  ->  Z
# Y  ->  Z

小破站讲解视频:汉诺塔实现讲解

相关推荐
李昊哲小课22 分钟前
第1章-PySide6 基础认知与环境配置
python·pyqt·pyside
2401_894241921 小时前
用Pygame开发你的第一个小游戏
jvm·数据库·python
Zzzz_my2 小时前
正则表达式(RE)
pytorch·python·正则表达式
天天鸭2 小时前
前端仔写了个 AI Agent,才发现大模型只干了 10% 的活
前端·python·ai编程
setmoon2143 小时前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
2401_833197733 小时前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python
敏编程4 小时前
一天一个Python库:tomlkit - 轻松解析和操作TOML配置
python
2401_879693874 小时前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
yunyun321234 小时前
机器学习模型部署:将模型转化为Web API
jvm·数据库·python
团子和二花5 小时前
openclaw平替之nanobot源码解析(七):Gateway与多渠道集成
python·gateway·agent·智能体·openclaw·nanobot