第十二周项目二 汉诺塔递归函数
来源:互联网 发布:xampp配置mysql端口 编辑:程序博客网 时间:2024/05/17 14:26
/**Copyright (c) 2014,烟台大学计算机学院*ALL right reserved*文件名;text.cpp*作者;刘佳琦*完成日期:2014年11月17日*版本号:v1.0*问题描述:汉诺塔移动盘子的问题*输入描述:输入n个盘子*程序输出:n个盘子移动方法*/#include <iostream>using namespace std;void move(int , char , char ,char);int main(){ int n; cin>>n; move(n,'A','B','C'); return 0;}//有n个盘子,void move(int n, char A, char B,char C){ if(n==1) cout<<"A"<<"→"<<"C"<<endl; else { move(n-1,A,C,B); cout<<A<<"→"<<C<<endl; move(n-1,B,A,C); }}
运行结果:
知识点总结:A中n-1个盘借助C移到B,再将A最大的一个移到C,再将B中的借助A移到C,当n=1时,最下面的大盘子由A到C,此时第一个调用结束,返回开始输出cout,此时的形参都改变,也就是实参B,C之间位置的互相改变,达到移动的目的,第二次调用是将B中的盘由A到C,和第一个一样,A,C互换位置,不断移动,也就是B的值赋给A(因为此时B相当于第一个的A),实参A,C互换位置,从头开始调用,再次第一次调用结束返回输出。
学习心得:刚开始研究了好久这个程序,上网查找也不是很懂,但是通过贺老师的讲解,再琢磨了以后终于明白了这个程序,其实也不是很难,主要找到规律,分为三步,明白递归调用的实际意义,分清实参与形参的关系,这个程序也就自然而然能够做出来了。
0 0
- 第十二周项目二 汉诺塔递归函数
- 第十二周项目1-3:递归函数
- 第十二周项目2-2:递归函数
- 第十二周项目3-用递归方法求解(二)
- 第十二周项目 1 阅读程序(递归函数)
- 第十二周 项目3:用递归函数求两数的最大公约数
- 第十二周项目包含递归函数的程序1
- 第十二周项目1递归函数的学习应用
- 第十二周项目1(6)递归函数
- 第十二周项目三—递归函数十进制转二进制
- 第十二周项目3递归函数求解(3)
- 第十二周项目一 阅读程序(3)递归函数
- 第十二周项目递归求解
- 第十二周项目二
- 第十二周项目二
- 第十二周项目二
- 第十二周项目二
- 第十二周项目二
- VC6++下的那些颜色
- EJB详解
- Qt Cursor
- 字符串大小比较的规则?
- 对.NET系统架构改造的一点经验和教训
- 第十二周项目二 汉诺塔递归函数
- 递进--求两个数的公约数
- 地柜函数实现二进制数
- 第11周 项目二 (1) 求两个数最大公约数
- 第十二周 项目二 (1)求多组数的最大公约数
- XHR2:让使用纯JS实现上传进度条变成了可能
- Unpack Png Files From The Plist File
- android-实时监听网络变化的工具类
- 时间设置对话框 DatePickerDialog的使用