hanoi(3,a,b,c);由于31因此進(jìn)入了遞歸的環(huán)節(jié)中。1執(zhí)行hanoi(2,a,c,b):這里代表剛才的步驟(1),將兩個盤子(盤盤2)從a移動到b,中間借助c。根據(jù)n=2的分析過程,必然是能夠達(dá)到我們的目的。
10年積累的網(wǎng)站設(shè)計、網(wǎng)站制作經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有班瑪免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
第一,把a(bǔ)上的n-1個盤通過c移動到b。第二,把a(bǔ)上的最下面的盤移到c。第三,因為n-1個盤全在b上了,所以把b當(dāng)做a重復(fù)以上步驟就好了。
hanoi(n-1,one,three,two);//當(dāng)有n個盤子,按照遞歸法,調(diào)用hannoi,先把//上面的n-1個盤子從第一根柱子(one)借助第三根柱子(three)移到第二根柱//子上(two)。
漢諾塔的一個經(jīng)典案例就是用遞歸法解決問題 A、B、C三根柱子上放盤子 開始盤子都在A上 盤子必須按照小上打下的順序放置 要求每次只能移動一個盤子 要將A上的盤子都移到B上。
第一步,n-1個金片從a經(jīng)c移動到b 不是“一步”完成的,而是“一個階段”(一次遞歸調(diào)用)完成的。在假定它完成的基礎(chǔ)上,第二步就可以完成了。
這樣,然而,完成第一步和第三步也同樣是一個移動n-1個盤子的漢諾塔問題。于是,遞歸調(diào)用在這里不可避免。程序你已經(jīng)寫的很清楚,給你解釋一下?,F(xiàn)把你的程序畫上行以便說明。
input the number of disks:3 the step to moving 3 disks A--C A--B C--B A--C B--A B--C A--C 紙筆畫了我老半天。。
大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。并且規(guī)定,在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動一個圓盤。
three)來實現(xiàn)的,我這樣寫只是便于理解遞歸過程,不知道是否理解?*/ } } void move(char x,char y){ printf(%c--%c\n,x,y);} /*move 函數(shù)只是起到一個打印步驟的作用,one對應(yīng)‘a(chǎn)’,。
1、確實,初學(xué)C的時候,漢諾塔的遞歸看起來確實是比較神奇的程序。其中主要就在hanoi 這個遞歸函數(shù),傳的參數(shù)里面有一個n 代表是幾層遞歸。如果n=1 代表只有一個,move(one,three); 就是把第一個移到第三個就行了。
2、第一步,n-1個金片從a經(jīng)c移動到b 不是“一步”完成的,而是“一個階段”(一次遞歸調(diào)用)完成的。在假定它完成的基礎(chǔ)上,第二步就可以完成了。
3、two)函數(shù),直到“n==1”} 執(zhí)行move(one, three);執(zhí)行hanoi(n-1, two, one, three){ 循環(huán)執(zhí)行hanoi(n-1, two, one, three),直到“n==1”} } 主要是遞歸的用法 好像解釋的不太清楚,但希望能幫到你。