汉诺塔程序详解

把A柱的碟盘移动到C柱上面

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <stdio.h>
#include <stdlib.h>
 
void hanoi(int n, char a, char b, char c);
 
void hanoi(int n, char a, char b, char c)
{
    if(n == 1) {
    printf("%d:%c to %c, ", n, a, c);
    }
    else{
        hanoi(n-1, a, c, b);                      //把A上n-1个盘子通过借助辅助塔(C塔)移到了B上
        printf("%d:%c to %c, ", n, a, c);
        hanoi(n-1, b, a, c);                      //把B上n-1个盘子通过借助辅助塔(A塔)移到了C上
    }
}
 
int main(void)
{
    hanoi(3, 'A', 'B', 'C');
    return EXIT_SUCCESS;
}

用的是递归方法

posted @   炽热的舞者  阅读(97)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示