簡單的漢諾塔問題解法代碼
以前學(xué)東西不扎實,現(xiàn)在撿撿也好,漢諾塔本是C語言開門就學(xué)的東西,不過上課那會兒真心聽不懂,直到大二了,才明白那是咋回事,我感覺的編程,真的是一張窗戶紙,不過捅破要花時間理解吸收。
題目描述:有一個塔,塔內(nèi)有A,B,C三個柱子。起初,A柱上有n個盤子,依次由大到小、從下往上堆放,要求將它們?nèi)恳频紺柱上;在移動過程中可以利用B柱,但每次只能移到一個盤子,且必須使三個柱子上始終保持大盤在下,小盤在上的狀態(tài)。要求編程輸出移動的步驟。
代碼如下:
#include<stdio.h>
int move(char one,char two)//這個函數(shù)就是為了輸出的結(jié)果直觀顯示出來,比如只有一個盤子時,輸出a-->c. 就這樣,把移動n個盤子每個步驟顯示出來
{
printf("%c --> %c\n",one,two);
}
int hanoi(int n,char one,char two,char three)//是核心函數(shù)了
{
int move(char one,char two);
if(n==1)//當(dāng)只有一個盤子時,直接從a柱移到c柱就好,也是遞歸程序的一個出口
move(one,three);
else{ //盤子大于一時
hanoi(n-1,one,three,two);//先借助c柱把上面的n-1個盤子從a柱全部移動到b柱
move(one,three); //這時a柱只剩下一個盤子了,移動到c柱即可
hanoi(n-1,two,one,three);//將b柱剩下的n-1個盤子借助a柱移動到c柱,任務(wù)也就完成了
}
}
int main()
{
int n;
char a,b,c;
while(scanf("%d",&n)!=EOF)//可以輸入多組數(shù)據(jù)檢驗結(jié)果
hanoi(n,'a','b','c');
}
相關(guān)文章
C語言結(jié)構(gòu)體嵌套與對齊超詳細(xì)講解
這篇文章主要介紹了C語言結(jié)構(gòu)體嵌套與對齊,C語言中結(jié)構(gòu)體是一種構(gòu)造類型,和數(shù)組、基本數(shù)據(jù)類型一樣,可以定義指向該種類型的指針。結(jié)構(gòu)體指針的定義類似其他基本數(shù)據(jù)類型的定義2022-12-12
C++中類的成員函數(shù)及內(nèi)聯(lián)函數(shù)使用及說明
這篇文章主要介紹了C++中類的成員函數(shù)及內(nèi)聯(lián)函數(shù)使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11

