汉诺塔程序详解
把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; } |
用的是递归方法
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)