代码注释很详细了
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int move(int N, char A, char B, char C) //N表示当前移动的几号盘
{
if (N == 1)
{
printf("圆盘%d,从%c移到%c!\n", N, A, C);
}
else
{
//当圆盘数量超过1时,需要将N-1个圆盘放在柱子B,再将最大的圆盘第N个圆盘放在柱子C
move(N - 1, A, C, B); //将N-1个圆盘放在柱子B
printf("圆盘%d,从%c移到%c!\n", N, A, C);
move(N - 1, B, C, A); //将N-1个圆盘放在柱子A
}
}
int main()
{
//汉诺塔算法——C语言递归实现
int N; //圆盘数量
char A = 'A', B = 'B', C = 'C'; // 柱子,数量是3个
scanf("%d", &N);
//初始条件下,圆盘全部放在柱子A,目标是将圆盘全部移到柱子C
printf("%d个圆盘\n", N);
move(N, A, B, C); //函数参数一定要初始化
return 0;
}
运行结果: