代码注释很详细了
#define _CRT_SECURE_NO_WARNINGS 1 #includeint 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; }
运行结果:



