運用遞迴解決漢諾塔問題(Python 3 0)

2021-09-16 13:18:18 字數 1118 閱讀 8309

漢諾塔:漢諾塔(又稱河內塔)問題是源於印度乙個古老傳說的益智玩具。大梵天創造世界的時候做了三根金剛石柱子,在一根柱子上從下往上按照大小順序摞著64片**圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。並且規定,在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動乙個圓盤。

具體**如下:

def hanoi

(n,x,y,z)

:if n==1:

print

(x,"-->"

,z)else

:hanoi

(n-1

,x,z,y) #將前(n-

1)個盤子從x移動到y上

print

(x,"-->"

,z) #將最後乙個盤子從x移動到z上

hanoi

(n-1

,y,x,z) #將y上的(n-

1)個盤子移動到z上

n=int

(input

('請輸入漢諾塔層數:'))

hanoi

(n,'x'

,'y'

,'z'

) #這裡x,y,z分別用字元x,y,z表示

#n=3時

請輸入漢諾塔層數:3

x --> z

x --> y

z --> y

x --> z

y --> x

y --> z

x --> z

#n=4時

請輸入漢諾塔層數:4

x --> y

x --> z

y --> z

x --> y

z --> x

z --> y

x --> y

x --> z

y --> z

y --> x

z --> x

y --> z

x --> y

x --> z

y --> z

遞迴解決漢諾塔問題

何為漢諾塔問題 漢諾塔 hanoi tower 又稱河內塔,源於印度乙個古老傳說。大梵天創造世界的時候做了三根金剛石柱子,在一根柱子上從下往上按照大小順序摞著64片 圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。並且規定,任何時候,在小圓盤上都不能放大圓盤,且在三根柱子之間...

遞迴解決漢諾塔問題

漢諾塔 漢諾塔 又稱河內塔 問題是源於印度乙個古老傳說的益智玩具。大梵天創造世界的時候做了三根金剛石柱子,在一根柱子上從下往上按照大小順序摞著64片 圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。並且規定,在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動乙個圓盤。c語言實...

遞迴解決漢諾塔問題

漢諾塔問題 有三根相鄰的柱子,標號為a,b,c,a柱子上從下到上按金字塔狀疊放著n個不同大小的圓盤,要把所有盤子乙個乙個移動到柱子b上,並且每次移動同一根柱子上都不能出現 子在小盤子上方,求至少需要多少次移動。我們首先假設n 1,那麼move n 1,因為這時候只需要從a c便可以。接下來假設n 2...