用Python代码写一个汉诺塔代码
时间: 2024-05-03 15:19:19 浏览: 116
下面是一个简单的 Python 实现汉诺塔游戏的代码:
```python
def hanoi(n, A, B, C):
if n == 1:
print(A, "-->", C)
else:
hanoi(n-1, A, C, B) # 将 n-1 个盘子从 A 移到 B
print(A, "-->", C) # 将第 n 个盘子从 A 移到 C
hanoi(n-1, B, A, C) # 将 n-1 个盘子从 B 移到 C
# 测试
hanoi(3, "A", "B", "C")
```
输出结果为:
```
A --> C
A --> B
C --> B
A --> C
B --> A
B --> C
A --> C
```
相关问题
使用python写一个汉诺塔算法
下面是一个 Python 实现的汉诺塔算法:
```python
def hanoi(n, a, b, c):
if n == 1:
print(a, '-->', c)
else:
hanoi(n-1, a, c, b)
print(a, '-->', c)
hanoi(n-1, b, a, c)
# 调用函数
hanoi(3, 'A', 'B', 'C')
```
上面的代码实现了将三个盘子从 A 移动到 C 的操作。其中,`n` 表示盘子的数量,`a`、`b`、`c` 分别表示三个柱子的名称。函数每次递归调用自身,将上方的 n-1 个盘子从 a 移动到 b,再将最下面的一个盘子从 a 移动到 c,最后将 b 上的 n-1 个盘子移动到 c。
用python写一个汉诺塔程序
下面是一个用 Python 实现的汉诺塔程序:
```python
def hanoi(n, source, target, auxiliary):
if n > 0:
# 将 n-1 个盘子从源柱移动到辅助柱
hanoi(n - 1, source, auxiliary, target)
# 将第 n 个盘子从源柱移动到目标柱
print("Move disk", n, "from", source, "to", target)
# 将 n-1 个盘子从辅助柱移动到目标柱
hanoi(n - 1, auxiliary, target, source)
# 测试代码
n = 3
hanoi(n, 'A', 'C', 'B')
```
运行结果:
```
Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 3 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C
```
其中 n 表示盘子的数量,source 表示源柱,target 表示目标柱,auxiliary 表示辅助柱。该程序使用递归实现汉诺塔,先将 n-1 个盘子从源柱移动到辅助柱,然后将第 n 个盘子从源柱移动到目标柱,最后将 n-1 个盘子从辅助柱移动到目标柱。
阅读全文