1時,需利用塔座Y作輔助塔座,若能設" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

漢諾塔遞歸解法

系統 1672 0

漢諾塔的遞歸算法


假設有3個分別命名為X、Y和Z的塔座,在塔座X上插有n個直徑大小各不相同、依小到大編號為1、2…n的圓盤。現要求將X軸上的n個圓盤移至塔座Z上并仍按同樣順序疊排,圓盤移動時必須遵守下列規則:
1、每次只能移動一個圓盤;
2、圓盤可以插在X、Y和Z中任一塔座上;
3、任何時刻都不能將一個較大的圓盤壓在較小的圓盤之上。


遞歸算法的思路:
當n=1時,問題比較簡單,只要將編號為1的圓盤從塔座X直接移至塔座Z上即可。
當n>1時,需利用塔座Y作輔助塔座,若能設法將壓在編號為n的圓盤之上的n-1個圓盤從塔座X移至塔座Y上,則可先將編號為n的圓盤從塔座X移至塔座Z上,然后再將塔座Y上的n-1個圓盤移至塔座Z上。而如何將n-1個圓盤從一個塔座移至另一個塔座的問題是一個和原問題具有相同特征屬性的問題,只是問題的規模小1,因此可以用同樣的方法求解。

      //從src移動第m個圓盤到dest底座上
void move(char src, int m, char dest){
	cout<<"the disk "<<m<<" is moved from src "
		<<src<<" to dest "<<dest<<endl;
}

//漢諾塔解法,將n個圓盤由x盤移動到z盤,y盤為輔助盤
void hanoi(int n, char x, char y, char z){
	if(n==1)move(x,1,z);
	else{
		hanoi(n-1, x,z,y);
		move(x,n,z);
		hanoi(n-1, y,x,z);
	}
}

int main(){
	hanoi(3,'x','y','z');
	return 0;
}
    

結果:

      the disk 1 is moved from src x to dest z
the disk 2 is moved from src x to dest y
the disk 1 is moved from src z to dest y
the disk 3 is moved from src x to dest z
the disk 1 is moved from src y to dest x
the disk 2 is moved from src y to dest z
the disk 1 is moved from src x to dest z
    

漢諾塔遞歸解法


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: www午夜视频 | 九草在线 | 午夜激情爱爱 | 精品久久久久一区二区国产 | 日本色综合 | 久在线视频 | 十六以下岁女子毛片免费 | 97精品超碰一区二区三区 | 国产精品亚洲综合 | 国产大陆精品另类xxxx | 男女进进出出动态图啪啪 | 久久97久久| 男女污网站 | 综合网天天色 | 日日摸夜夜添夜夜添精品视频 | 97精品国产高清在线看入口 | 亚洲成aⅴ人在线观看 | 国产精品视频免费 | 亚洲天堂久久 | 日本娇小videos高潮 | 91精品国产综合久久久蜜臀粉嫩 | 天堂资源| 澳门久久精品 | 国产一区二区三区久久久久久久久 | 亚洲欧美视频在线 | 亚洲成人动漫在线观看 | 香港三级午夜理伦三级 | 2015小明看日韩成人免费视频 | 在线视频观看国产 | 国产在线激情 | 999精品久久久 | 国产精品久久久久久久久久 | 久久中文字幕一区二区 | 日韩成人免费视频 | 日韩小视频 | 精品一区二区三区在线播放 | 成年美女黄的视频网站 | 国产一区二区在线看 | 亚州精品天堂中文字幕 | 国产精品久久久久久久网站 | 久久精品国产线看观看亚洲 |