下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第C語言編寫漢諾塔游戲目錄漢諾塔的游戲規(guī)則:當(dāng)A只有一個環(huán)的時候:當(dāng)A只有兩個環(huán)的時候:當(dāng)A只有三個環(huán)的時候:思路:當(dāng)n=1時:當(dāng)n=2時:當(dāng)n=3時:當(dāng)n=4時:見代碼運行截圖總結(jié)
漢諾塔的游戲規(guī)則:
有三根金剛石柱子A、B、C,在A柱子上從下往上按照大小依次減小的順序摞著64片黃金環(huán)。大梵天命令婆羅門把環(huán)從下面開始按大小順序重新擺放在另一根柱子上。并且規(guī)定,在任何一個柱子上,小環(huán)上不能放大環(huán),在三根柱子之間一次只能移動一個環(huán)。
即將A柱子上全部的環(huán)通過C柱子(C柱子作為中介)移動到B柱子上
當(dāng)A只有一個環(huán)的時候:
A-B
當(dāng)A只有兩個環(huán)的時候:
A-C
A-B
C-B
當(dāng)A只有三個環(huán)的時候:
A-B
A-C
B-C
A-B
C-A
C-B
A-B
思路:
1、將n-1個環(huán)先放到C柱子上
2、將A柱子上的最后一個環(huán)移動到B柱子上
3、將n-1個環(huán)從C柱子移動到B柱子上
當(dāng)n=1時:
1、將0個環(huán)先放到C柱子上
2、將A柱子上的最后一個環(huán)移動到B柱子上:A-B
3、將0個環(huán)從C柱子移動到B柱子上
當(dāng)n=2時:
1、將1個環(huán)先放到B柱子上:A-C
2、將A柱子上的最后一個環(huán)移動到B柱子上:A-B
3、將1個環(huán)從C柱子移動到B柱子上:C-B
當(dāng)n=3時:
1、將2個環(huán)先放到C柱子上:使用遞歸將2個環(huán)放到C上,因為A柱子的最后一個環(huán)是最大的因此可以先不理會,遞歸重復(fù)當(dāng)n=2時的步驟,不過是從將2個環(huán)從A放到B上改為將2個環(huán)從A放到C上了
2、將A柱子上的最后一個環(huán)移動到B柱子上:A-B
3、將2個環(huán)從C柱子移動到B柱子上:使用遞歸將2個環(huán)從C柱子移動到B柱子上,此時B柱子上已經(jīng)有了最大的一個環(huán)因此可以不用再理會了,遞歸重復(fù)當(dāng)n=2的步驟,不過是從將2個環(huán)從A放到B上改為將2個環(huán)從C放到B上了
當(dāng)n=4時:
1、將3個環(huán)先放到C柱子上:遞歸重復(fù)n=3的步驟,不過是從將3個環(huán)從A放到B上改為將3個環(huán)從A放到C上了
2、將A柱子上的最后一個環(huán)移動到B柱子上:A-B
3、將3個環(huán)從C柱子移動到B柱子上:遞歸重復(fù)當(dāng)n=3的步驟,不過是從將3個環(huán)從A放到B上改為將3個環(huán)從C放到B上了
見代碼
#includestdio.h
voidhanoi(intnum,charsou,chartar,charaux){
//統(tǒng)計移動次數(shù)
staticinti=1;
//如果圓盤數(shù)量僅有1個,則直接從起始柱移動到目標(biāo)柱
if(num==1){
printf("第%2d次:從%c移動至%c\n",i,sou,tar);
i++;
else{
//遞歸調(diào)用hanoi()函數(shù),將num-1個圓盤從起始柱移動到輔助柱上
hanoi(num-1,sou,aux,tar);
//將起始柱上剩余的最后一個大圓盤移動到目標(biāo)柱上
printf("第%2d次:從%c移動至%c\n",i,sou,tar);
i++;
//遞歸調(diào)用hanoi()函數(shù),將輔助柱上的num-1圓盤移動到目標(biāo)柱上
hanoi(num-1,aux,tar,sou);
intmain()
intn=0;
scanf("%d",
//起始柱、目標(biāo)柱、輔助柱分別用A、B、C表示
hanoi(n,'A','B','C'
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年中職老年服務(wù)與管理(養(yǎng)老服務(wù))試題及答案
- 2025年高職水產(chǎn)養(yǎng)殖學(xué)(水產(chǎn)動物養(yǎng)殖)試題及答案
- 2025年高職(新能源汽車檢測與維修)維修技術(shù)試題及答案
- 2025年高職助產(chǎn)學(xué)(產(chǎn)科護(hù)理技術(shù))試題及答案
- 禁毒安全教育內(nèi)容課件
- 口腔醫(yī)學(xué)考研就業(yè)前景
- 2026年幼兒春節(jié)故事歡歡喜喜過大年
- 光伏技術(shù)交底全套
- 光伏培訓(xùn)教學(xué)課件
- 2024黑龍江省各級機關(guān)考試錄用公務(wù)員備考題庫及參考答案詳解
- TOC基本課程講義學(xué)員版-王仕斌
- T-GDWCA 0035-2018 HDMI 連接線標(biāo)準(zhǔn)規(guī)范
- 面板堆石壩面板滑模結(jié)構(gòu)設(shè)計
- 初中語文新課程標(biāo)準(zhǔn)與解讀課件
- 無人機裝調(diào)檢修工培訓(xùn)計劃及大綱
- 中建通風(fēng)與空調(diào)施工方案
- 高考語言運用題型之長短句變換 學(xué)案(含答案)
- 春よ、來い(春天來了)高木綾子演奏長笛曲譜鋼琴伴奏
- ARJ21機型理論知識考試題庫(匯總版)
- 2023年婁底市建設(shè)系統(tǒng)事業(yè)單位招聘考試筆試模擬試題及答案解析
- GB/T 4623-2014環(huán)形混凝土電桿
評論
0/150
提交評論