博客
关于我
汉诺塔 C++实现【STL stack】
阅读量:363 次
发布时间:2019-03-04

本文共 2524 字,大约阅读时间需要 8 分钟。

首先我们对题目重现:

汉诺塔:汉诺塔(Tower of Hanoi)源于印度传说中,大梵天创造世界时造了三根金钢石柱子,其中一根柱子自底向上叠着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。有三根杆子A,B,C。A杆上有N个(N>1)穿孔圆盘,盘的尺寸由下到上依次变小.要求按下列规则将所有圆盘移至C杆:
1.每次只能移动一个圆盘;
2.大盘不能叠在小盘上面.
可将圆盘临时置于B杆,也可将从A杆移出的圆盘重新移回A杆,但都必须尊循上述两条规则。
求移动的过程。
在这里我们对他的移动过程具象化,达到这样的效果:
在这里插入图片描述
首行输入3,接下来是用1, 2, 3代表他的大小等级。
是不是挺形象生动的。

算法思考:

对于汉诺塔,我们用的是递归的思想。对于N层的汉诺塔,我们只需要将前n-1层的汉诺塔移到B柱上,接下来将第n层移动到C,接着,将前n-1的汉诺塔移动到C上。因为越往底层,移动次数越少,所以在对前n-1项进行分析的时候,不需要对下层的进行管理。

代码实现:

首先是C++ 的基本框架:

#include
using namespace std;int main() { turn 0;}

在这里为了方便管理,所以用到了栈来进行数据储存,并且方便后面的运算,我们将栈放到主函数外面。

#include
#include
using namespace std;int num;stack
a, b, c;//三个塔int main() { cin >> num;// 输入汉诺塔层数 for (int i = num; i > 0; i--) // 将A塔填充完毕 a.push(i); turn 0;}

接下来,我们开始实现汉诺塔的主函数,递归的思想:

#include
#include
using namespace std;int num;stack
a, b, c; //三个塔void move(int n, stack
&s, stack
& t, stack
& l) { //我们将目前所在塔,需要借助的塔,和目标塔分别定义成s, t, l if (n == 1) { //当我们找到顶层的塔,进行移动 l.push(s.top()); s.pop(); } else { move(n - 1, s, l, t); //将前n-1层塔从s通过l移动到t塔上,方便我们将最底层塔移动到l上 l.push(s.top()); //将第n层塔移动到l塔上 s.pop(); move(n - 1, t, s, l);//再将t上的塔结束s移动到l上,完成汉诺塔的移动 }}int main() { cin >> num; // 输入汉诺塔层数 for (int i = num; i > 0; i--) // 将A塔填充完毕 a.push(i); move(num, a, b, c); return 0;}

如此我们就将整个汉诺塔的数据操作完成了,接下来我们需要将他可视化:

我们通过display来显示:

#include
#include
using namespace std;int num;stack
a, b, c; //三个塔void display() { auto temp1 = a; auto temp2 = b; auto temp3 = c; for (int i = num-1; i >= 0; i--) { if (i < a.size()) { cout << temp1.top() << ' '; temp1.pop(); } else cout << " "; if (i < b.size()) { cout << temp2.top() << ' '; temp2.pop(); } else cout << " "; if (i < c.size()) { cout << temp3.top() << endl; temp3.pop(); } else cout << endl; } cout << endl;}void move(int n, stack
&s, stack
& t, stack
& l) { //我们将目前所在塔,需要借助的塔,和目标塔分别定义成s, t, l if (n == 1) { //当我们找到顶层的塔,进行移动 l.push(s.top()); s.pop(); display(); } else { move(n - 1, s, l, t); //将前n-1层塔从s通过l移动到t塔上,方便我们将最底层塔移动到l上 l.push(s.top()); //将第n层塔移动到l塔上 s.pop(); display(); move(n - 1, t, s, l);//再将t上的塔结束s移动到l上,完成汉诺塔的移动 }}int main() { cin >> num; // 输入汉诺塔层数 for (int i = num; i > 0; i--) // 将A塔填充完毕 a.push(i); display(); move(num, a, b, c); return 0;}

我们之前之所以将数据定义在main函数外面,也是为了display的

转载地址:http://vuyg.baihongyu.com/

你可能感兴趣的文章
JDBC连接数据库
查看>>
嵌入式系统设计师学习笔记⑥:存储器的层次架构及Cache详解
查看>>
codeforces255C.Almost Arithmetical Progression
查看>>
2019CCPC女生专场赛_K - Tetris_打表/模拟_暴力之王
查看>>
服务器下载部署配置nginx,实现nginx代理多个项目
查看>>
P1125 [NOIP2008 提高组] 笨小猴 (Java)
查看>>
HDU1559(二维前缀和模板 Java&C++)
查看>>
ASP.NET AJAX---UpdatePanel控件小实例(时间的局部更新&条件更新)
查看>>
ASP.NET javascript实现图片切换
查看>>
ASP.NET jQuery 小实例(实现图片的放大&缩小)
查看>>
IIS express web 无法启动服务器
查看>>
“/”应用程序中的服务器错误。
查看>>
MUI之ajax获取后台接口数据
查看>>
使用sqlserver 查询不连续的数据
查看>>
用div+css+html+js 实现图片放大
查看>>
mui+vue.js实现上拉刷新和下拉加载
查看>>
mui返回到父页页面并进行刷新
查看>>
数据库中优化lock
查看>>
layui 点击选择框为啥会出现震动(已解决)
查看>>
地图划范围
查看>>