c 语言求汉诺塔问题
时间: 2024-01-23 17:09:29 浏览: 105
汉诺塔问题是经典的递归问题,可以使用递归算法来解决。以下是 C 语言求解汉诺塔问题的代码实现:
```c
#include <stdio.h>
void hanoi(int n, char A, char B, char C) {
if (n == 1) {
printf("Move disk %d from %c to %c\n", n, A, C);
return;
}
hanoi(n-1, A, C, B);
printf("Move disk %d from %c to %c\n", n, A, C);
hanoi(n-1, B, A, C);
}
int main() {
int n;
printf("Enter the number of disks: ");
scanf("%d", &n);
hanoi(n, 'A', 'B', 'C');
return 0;
}
```
运行代码,输入盘子的数量,即可输出移动过程。
相关问题
p ython实现汉诺塔
汉诺塔是一种经典的递归问题,以下是 Python 实现:
```python
def hanoi(n, start, target, aux):
if n == 1:
print(f"Move disk 1 from {start} to {target}")
return
hanoi(n-1, start, aux, target)
print(f"Move disk {n} from {start} to {target}")
hanoi(n-1, aux, target, start)
# 测试
hanoi(3, '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 个盘子需要从起始柱子移动到目标柱子,可以将此问题拆解为三个子问题:将前 n-1 个盘子从起始柱子移动到辅助柱子、将第 n 个盘子从起始柱子移动到目标柱子、将前 n-1 个盘子从辅助柱子移动到目标柱子。由于子问题的规模都是 n-1,因此可以使用递归来解决问题。需要注意的是,每次移动盘子时需要输出移动的步骤。
p y t hon汉诺塔递归
汉诺塔问题是一个经典的递归问题,可以使用递归算法来解决。下面是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)
```
其中,n表示盘子的数量,a、b、c分别表示三个柱子。在汉诺塔问题中,我们要将n个盘子从柱子a移动到柱子c,可以借助柱子b。这个问题可以分解成三个子问题:
1. 将n-1个盘子从a移动到b,可以借助c;
2. 将最后一个盘子从a移动到c;
3. 将n-1个盘子从b移动到c,可以借助a。
递归调用函数hanoi()可以解决这个问题。当n=1时,直接将盘子从a移动到c即可;当n>1时,先将前n-1个盘子从a移动到b,然后将最后一个盘子从a移动到c,最后将前n-1个盘子从b移动到c即可。
阅读全文
相关推荐











