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

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

漢諾塔遞歸解法

系統 1806 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條評論
主站蜘蛛池模板: 亚洲欧美婷婷 | 久久中文精品 | 日韩精品123 | 国产精品永久免费视频观看 | 国内精品小视频在线 | 99精品国产在热久久 | 99精品视频观看 | 日日摸夜夜添夜夜添一区二区 | 国产精品久久久久国产精品 | 香蕉国产人午夜视频在线 | 国产欧美另类久久久精品免费 | 久久国产精品99精品国产 | 国产精品123区| 亚洲热热久久九九精品 | 两性视频网站 | 久久永久免费 | 亚洲国产精品综合久久网络 | 久久国产精品免费看 | 久久这里只精品国产99热 | 亚洲日本人成中文字幕 | 国产人做人爱视频精品 | 在线不欧美 | 香蕉成人影院 | 日韩毛片免费观看 | 久久久久女人精品毛片 | 香蕉福利久久福利久久香蕉 | 精品xxxxxbbbb欧美中文 | 日本中文字幕在线观看视频 | youjizz欧美粗又大中国 | 欧美成人午夜在线全部免费 | 欧美激情在线 | 久久精品国产只有精品6 | www.狠狠艹 | 毛片免 | 天天综合天天操 | 亚洲天天做日日做天天欢毛片 | 毛片毛片毛片毛片毛片 | 午夜爱爱网 | 日韩在线中文字幕 | 91精选| 久久久久久久久久爱 |