汉诺塔用python实现的几种写法

其实都算是同一种,茴香豆?

听说有人将64层圆盘移完后。

彼时,四极废,九州裂,天不兼覆,地不周载。

一种汉诺塔

def hanoi(n, a, b, c):
    if n > 0:
        hanoi(n-1, a, c, b)  # 将n-1个盘子从a移动到b
        print(f"Move disk from {a} to {c}")  # 移动编号最大的盘子从a到c
        hanoi(n-1, b, a, c)  # 再将n-1个盘子从b移动到c

# 使用函数
n = 3  # 设定盘子的数量
hanoi(n, 'A', 'B', 'C')  # 执行汉诺塔移动
Move disk from A to C
Move disk from A to B
Move disk from C to B
Move disk from A to C
Move disk from B to A
Move disk from B to C
Move disk from A to C
[Finished in 42ms]

另一种汉诺塔

这种把圆盘编号都加上了

def move(m, A, C):
    """将编号为m的圆盘从柱子A移动到柱子C"""
    print(f'移动{m}号圆盘,{A} ---> {C}')

def hanoi(n, A, B, C):
    """将n个圆盘从柱子A借助柱子B移动到柱子C"""
    if n == 1:
        # 将圆盘从柱子A移动到柱子C
        move(1, A, C)
    else:
        # 将柱子A上面编号为1至n-1的圆盘从柱子A借助柱子C移动到柱子B
        hanoi(n - 1, A, C, B)
        # 将柱子A最下面编号为n的圆盘从柱子A移动到柱子C
        move(n, A, C)
        # 将柱子B的n-1个圆盘从柱子B借助柱子A移动到柱子C
        hanoi(n - 1, B, A, C)

hanoi(3, 'A', 'B', 'C')

圆盘编号都加上,就很具象化了

运行结果:

移动1号圆盘,A ---> C
移动2号圆盘,A ---> B
移动1号圆盘,C ---> B
移动3号圆盘,A ---> C
移动1号圆盘,B ---> A
移动2号圆盘,B ---> C
移动1号圆盘,A ---> C
[Finished in 41ms]

常见的一种汉诺塔

def Hanoi(n, current, transit, target):
    if n == 1:
        print(current, "-->", target)
    else:
        Hanoi(n - 1, current, target, transit)
        print(current, "-->", target)
        Hanoi(n - 1, transit, current, target)
 
 
num = int(input("输入汉诺塔的层数:"))
Hanoi(num, 'A', 'B', 'C')
A --> C
A --> B
C --> B
A --> C
B --> A
B --> C
A --> C
[Finished in 41ms]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值