国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++ 實(shí)現(xiàn)漢諾塔的實(shí)例詳解

2020-01-26 13:57:08
字體:
供稿:網(wǎng)友

C++ 實(shí)現(xiàn)漢諾塔的實(shí)例詳解

前言:

有A,B,C三塔,N個(gè)盤(從小到大編號(hào)為1-N)起初都在A塔,現(xiàn)要將N個(gè)盤全部移動(dòng)到C塔(按照河內(nèi)塔規(guī)則),求最少移動(dòng)次數(shù)以及每次的移動(dòng)詳細(xì)情況。

要求:

需要采用遞歸方法和消除尾遞歸兩種方法編寫。

盤數(shù)N由用戶從標(biāo)準(zhǔn)輸入讀入,以一個(gè)整數(shù)表示,然后請調(diào)用兩個(gè)方法按照下面例子所述分別在屏幕中輸出結(jié)果(正常情況下一個(gè)輸入數(shù)據(jù)會(huì)顯示同樣的輸出結(jié)果2次)。

實(shí)現(xiàn)代碼:

#include<iostream>using namespace std;void move(int count,char start='a',char finish='b',char temp='c'){ if(count>0) {  move(count-1,start,temp,finish); cout<<"Move "<<count<<" from "<<start<<" to "<<finish<<endl; move(count-1,temp,finish,start); }}void move_without_recursion(int count,char start='a',char finish='b',char temp='c'){ char swap; while(count>0) {  move_without_recursion(count-1,start,temp,finish); cout<<"Move "<<count<<" from "<<start<<" to "<<finish<<endl; count--; swap=start; start=temp; temp=swap; }}int main(){ int count; cout<<"please enter the number:"; cin>>count; cout<<"遞歸方法運(yùn)行過程:"<<endl;  move(count);  cout<<"消除尾遞歸方法運(yùn)行過程:"<<endl;  move_without_recursion(count);return 0;}

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 高雄市| 莱阳市| 潮州市| 从江县| 玉田县| 柞水县| 石台县| 蓬莱市| 淮北市| 宝丰县| 凤台县| 克东县| 仁布县| 巴林左旗| 五河县| 林口县| 高淳县| 东港市| 新民市| 赞皇县| 永仁县| 东平县| 阿拉尔市| 库伦旗| 新和县| 新化县| 晋中市| 平远县| 芮城县| 安达市| 开原市| 栖霞市| 塔河县| 定襄县| 沙田区| 洛川县| 鹤山市| 集安市| 长葛市| 鹤庆县| 芮城县|