第三周C++练习之汉诺塔问题
来源:互联网 发布:狄山 知乎 编辑:程序博客网 时间:2024/04/28 01:05
/* *Copyright(c) 2016,烟台大学计算机学院 *All rights reserved. *文件名称:test2.cpp *作 者:刘金石 *完成日期:2016年3月19日 *版本 号:v1.0 *问题描述:汉诺塔问题 *输入描述:输入需要移动盘子的数量。 *输出描述:输出移动步骤。 */ #include<iostream>using namespace std;void hanoi(int n,char src,char medium,char dest);void move(char src,char dest);int main(){ int m; cout<<"Enter the number of diskes:"<<endl; cin>>m; cout<<"the step to moving "<<m<<" diskes:"<<endl; hanoi(m,'A','B','C'); return 0;}void hanoi(int n,char src,char medium,char dest){ if(n==1) move(src,dest); else { hanoi(n-1,src,dest,medium);//把n-1个盘子由src移到medium,借助于dest, move(src,dest); hanoi(n-1,medium,src,dest);//再把n-1个盘子由medium移到dest,借助于src }}void move(char src,char dest){ cout<<src<<"-->"<<dest<<endl;
运行结果:
<img src="http://img.blog.csdn.net/20160319111947001?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />
编程心得:
<span style="white-space:pre"></span>通过这次汉诺塔问题,使自己更加深刻的理解函数递归,以及用递归来解决复杂的问题。就拿本题来说,要把n个盘子移动到dest上,首先要把上面n-1盘子移动到medium上,然后再把最后一个盘子从src直接移动到dest上去。但是把n-1个盘子由src移到medium上显然不能一步完成,要先把n-2个盘子移动到dest上,再把src上的第n-1个盘子移动到medium上……以此类推.最后把最大的盘子移到dest上,然后再把第n-1个盘子移到dest上,以此类推.
0 0
- 第三周C++练习之汉诺塔问题
- C语言第三课练习
- 第三周练习计划
- 第三周JAVA练习
- 【C程序设计语言】第三章-控制流 | 练习
- C和指针第三章--编程练习
- C++PRIMER第三章课后练习
- 我的第三个C程序练习
- C语言练习 (典型递归问题)汉诺塔问题
- 第三周练习 求最大公约数
- 第三周练习 递归1
- 第三周练习-4 fib
- 编程练习(第三周)
- 练习五(第三周)
- 练习四(第三周)
- 练习四(第三周)
- 练习五(第三周)
- C语言问题练习1
- 搜狐Java开发实习生笔试题
- javascript表单验证
- curl监控站点响应时间
- 边界环绕路径
- 返回函数和闭包
- 第三周C++练习之汉诺塔问题
- 为什么我用了VPN,本地IP还是没有变化
- Codeforces 637D Running with Obstacles 【贪心】
- xampp启动Apache时报错80端口被占用
- ES2015 - Generator function (2)
- java语言程序设计课后题----复习题/Chapter21泛型
- CodeForces - 651A Joysticks (找规律&模拟)水
- Java注释常用标签实例
- Hello world!