0

0

c++ 汉诺塔递归代码 c++汉诺塔算法图解

尼克

尼克

发布时间:2025-12-06 08:03:06

|

244人浏览过

|

来源于php中文网

原创

汉诺塔问题通过递归实现,将n个盘子从A移动到C,需借助B辅助。首先将前n-1个盘子从A移到B,再将最大盘从A移到C,最后将n-1个盘子从B移到C。每次移动遵循大盘不压小盘原则。递归终止条件为只剩一个盘子时直接移动。算法体现分治思想,通过不断分解问题规模直至可直接求解。

c++ 汉诺塔递归代码 c++汉诺塔算法图解

汉诺塔问题是递归算法的经典例子,通过将问题分解为更小的子问题来解决。下面给出 C++ 实现代码,并附上算法执行过程的图解说明。

汉诺塔问题描述

有三根柱子 A、B、C,A 上有 n 个大小不同的圆盘,按从小到大的顺序叠放(大盘在下)。目标是把所有圆盘从 A 移动到 C,移动过程中遵守以下规则:

  • 一次只能移动一个圆盘
  • 每次移动的是某根柱子最上面的圆盘
  • 大盘不能放在小盘之上

C++ 递归实现代码

#include 
using namespace std;

void hanoi(int n, char from, char to, char aux) { if (n == 1) { cout << "将盘子 " << n << " 从 " << from << " 移动到 " << to << endl; return; } hanoi(n - 1, from, aux, to); // 先把上面 n-1 个移到辅助柱 cout << "将盘子 " << n << " 从 " << from << " 移动到 " << to << endl; hanoi(n - 1, aux, to, from); // 再把 n-1 个从辅助柱移到目标柱 }

int main() { int n; cout << "输入盘子数量:"; cin >> n; hanoi(n, 'A', 'C', 'B'); return 0; }

输出示例(n=3):

将盘子 1 从 A 移动到 C
将盘子 2 从 A 移动到 B
将盘子 1 从 C 移动到 B
将盘子 3 从 A 移动到 C
将盘子 1 从 B 移动到 A
将盘子 2 从 B 移动到 C
将盘子 1 从 A 移动到 C

算法图解与执行逻辑

以 n = 3 为例,三步递归策略如下:

立即学习C++免费学习笔记(深入)”;

第1步:将前2个盘子从 A → B(借助 C)

Sora
Sora

Sora是OpenAI发布的一种文生视频AI大模型,可以根据文本指令创建现实和富有想象力的场景。

下载
  • 把最上面两个盘子看作一个整体,先移到辅助柱 B
  • 这需要递归调用 hanoi(2, A, B, C)

第2步:将最大盘子从 A → C

  • 此时 A 上只剩最大盘(第3个),直接移动到目标柱 C

第3步:将2个盘子从 B → C(借助 A)

  • 递归地把 B 上的两个盘子移到 C,完成最终目标

整个过程体现“分治”思想:要移动 n 层塔,先移上面 n-1 层让路,再移动底层,最后把 n-1 层盖上去。

递归调用结构图(简化表示)

hanoi(3, A→C)
├─ hanoi(2, A→B)
│  ├─ hanoi(1, A→C): A→C
│  ├─ A→B
│  └─ hanoi(1, C→B): C→B
├─ A→C
└─ hanoi(2, B→C)
   ├─ hanoi(1, B→A): B→A
   ├─ B→C
   └─ hanoi(1, A→C): A→C

每层递归都在缩小问题规模,直到只剩一个盘子时直接处理,这是递归终止条件。

基本上就这些。理解关键在于相信递归能处理好 n-1 的情况,你只需专注当前一层的操作逻辑。不复杂但容易忽略细节。

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

404

2023.08.14

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

28

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

20

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

52

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号