汉诺卡Hanoi问题详解
来源:互联网 发布:python培训机构 编辑:程序博客网 时间:2024/06/05 03:26
有三根相邻的柱子,标号为A,B,C,A柱子上从下到上按金字塔状叠放着n个不同大小的圆盘,要把所有盘子一个一个移动到柱子B上,并且每次移动同一根柱子上都不能出现大盘子在小盘子上方,请问至少需要多少次移动,设移动次数为H(n)。
#include<iostream>using namespace std;//例如有N和盘子在A柱子上,要移到C上,B是中转站作用。//分解简化一下问题,//① 我需要把N-1个盘子先移到B上,//② 再把剩下的1个盘子从A移动到C,直接输出即可//③ 然后把B上的N-1歌盘子移动到C,//就完成了//然后用这个思想写出递归//如下//汉诺卡问题void Hanoi(int n,char a,char b,char c)//A到C,B做中转{ if (n==1)//若就一个盘子,就直接A到C,没毛病吧,老铁? { cout << a << "--->" << c << endl;//输出步骤 return; } Hanoi(n-1,a,c,b);//① //A到B,C做中转 cout << a << "--->" << c << endl;//② Hanoi(n-1,b,a,c);//③ //B到C,A做中转 return;}int main(){ int n; cin >> n; Hanoi(n,'A','B','C'); return 0;}
0 0
- 汉诺卡Hanoi问题详解
- hanoi问题详解
- Hanoi 问题
- hanoi问题
- Hanoi问题
- Hanoi问题
- hanoi问题
- hanoi问题
- Hanoi问题
- Hanoi问题
- hanoi问题
- Hanoi问题
- Hanoi 问题
- hanoi问题
- hanoi问题
- Hanoi双塔问题(hanoi)
- 汉诺塔(hanoi)详解
- Hanoi塔问题
- [Android]解决org.gradle.api.internal.tasks.DefaultTaskInputs$TaskInputUnionFileCollection cannot be ca
- DELL T7600工作站重新安装WIN7系统
- 文章标题
- java.lang.IllegalStateException: No output folder 解决方案
- QT使用插件QAxWidget
- 汉诺卡Hanoi问题详解
- javaee中过滤器的理解
- 什么? 模拟器看着不爽?用USB真机调试太啰嗦?快用AndroidWifiADB无线真机调试吧
- php 子类中如何调用父类的变量和方法
- 剑指offer-54.字符流中第一个不重复的字符
- apache端口冲突
- 判断大小写的高效方式
- 关于使用GHOST进行磁盘对拷整盘镜像以及镜像恢复的一些注意事项
- elasticsearch 中文分词