当前位置: 首页 > news >正文

东方博宜OJ 1222:经典递归问题 —— 汉诺塔

【题目来源】
https://oj.czos.cn/p/1222

【题目描述】
汉诺塔(又称河内塔)问题是印度的一个古老的传说。开天辟地的神勃拉玛在一个庙里留下了三根金刚石的棒,第一根上面套着 64 个圆的金片,最大的一个在底下,其余一个比一个小,依次叠上去,庙里的众僧不倦地把它们一个个地从这根棒搬到另一根棒上,规定可利用中间的一根棒作为帮助,但每次只能搬一个,而且大的不能放在小的上面。
面对庞大的数字(移动圆片的次数)
18446744073709551615,看来,众僧们耗尽毕生精力也不可能完成金片的移动。

后来,这个传说就演变为汉诺塔游戏:
1.有三根杆子 A,B,C。A 杆上有若干碟子。
2.每次移动一块碟子,小的只能叠在大的上面。
3.把所有碟子从 A 杆全部移到 C 杆上。
经过研究发现,汉诺塔的破解很简单,就是按照移动规则向一个方向移动金片:如 3 阶汉诺塔的移动:A→C, A→B, C→B, A→C, B→A, B→C, A→C。
此外,汉诺塔问题也是程序设计中的经典递归问题。
算法思路:
1.如果只有一个金片,则把该金片从源移动到目标棒,结束。
2.如果有 n 个金片,则把前 n-1 个金片移动到辅助的棒,然后把自己移动到目标棒,最后再把前 n-1 个移动到目标棒。

【输入格式】
一个整数 N,表示 A 柱上有 N 个碟子。(0<n≤10)

【输出格式】
若干行,即移动的最少步骤。

【输入样例】
3

【输出样例】
A To C
A To B
C To B
A To C
B To A
B To C
A To C

【数据范围】
0<n≤10​​​​​​​

【算法分析】
经典递归问题。

【算法代码】

#include <bits/stdc++.h> using namespace std; void hnt(int n,char x,char y,char z) { if(n==0) return; hnt(n-1,x,z,y); cout<<x<<" To "<<z<<endl; hnt(n-1,y,x,z); } int main() { int n; cin>>n; hnt(n,'A','B','C'); return 0; } /* in: 3 out: A To C A To B C To B A To C B To A B To C A To C */





【参考文献】
https://blog.csdn.net/hnjzsyjyj/article/details/115372258
https://oj.czos.cn/p/1222




http://www.cnnetsun.cn/news/119596.html

相关文章:

  • 终极免费抽奖神器:Magpie-LuckyDraw全平台部署指南
  • 技术人才职业发展:从工具思维到价值创造的成长阶梯
  • 百度贴吧用户脚本终极指南:告别繁琐操作,体验贴吧新境界
  • 等待节点-–-behaviac
  • Nginx性能优化实战:从基础配置到高级调优的完整指南
  • ThingsGateway:开源智能设备管理平台的终极指南
  • KolodaView开源项目贡献指南
  • 5‘-Thiol Modifier C6 S-S Amidite,5‘-硫醇修饰剂 C6 双硫键核苷酸酰胺化试剂
  • Python:SOLID 面向对象设计原则
  • 专业级鼠标性能测试工具:从数据采集到精准分析的全链路解析
  • Magpie-LuckyDraw:5分钟上手的多平台炫酷抽奖系统终极指南
  • 魔兽争霸III现代化修复工具:全面解决兼容性问题的终极指南
  • 数字内容获取革命:智能绕过付费墙的完整解决方案
  • 256台H100服务器算力中心的带外管理网络建设方案
  • 深入理解指针(7)
  • 从卷 Java 到冲网安!计算机人 2025 自救路线:附 40-150 万安全岗 + 技能衔接清单
  • python大数据的基于k-means算法的校园美食推荐系统_j4eg7g7z--论文
  • MouseTester专业指南:3步完成鼠标性能精准诊断
  • [鸿蒙2025领航者闯关]图标资源统一管理
  • 区分__proto__和prototype
  • 西门子PLC地址知识点
  • EmotiVoice开源项目依赖项管理最佳实践
  • 如何彻底解决腾讯游戏卡顿问题:sguard_limit资源限制器完整指南
  • MiniGPT-4终极优化指南:5个简单技巧实现3倍推理加速
  • 鼠标性能测试终极指南:从新手到专家的完整解决方案
  • 终极指南:如何用pbxproj轻松玩转Xcode项目文件
  • 移动端AI部署革命:Paddle-Lite如何让深度学习模型在手机上流畅运行
  • 类型安全强化学习实战:从Gymnasium类型提示到项目稳健性提升
  • OBS直播教程:OBS多路推流插件如何下载?如何安装?怎么用?
  • ComfyUI-Manager依赖安装:5分钟搞定pip与uv的完美切换