91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python實現的漢諾塔算法示例

發布時間:2020-09-02 15:14:05 來源:腳本之家 閱讀:157 作者:鯨落丶 欄目:開發技術

本文實例講述了python實現的漢諾塔算法。分享給大家供大家參考,具體如下:

python實現的漢諾塔算法示例

規則:

圓盤從下面開始按大小順序重新擺放在另一根柱子上。并且規定

  • 在小圓盤上不能放大圓盤
  • 在三根柱子之間一次只能移動一個圓盤。

算法思路:【三階的移動思路】

python實現的漢諾塔算法示例

python實現:[注意實參和形參]

    用python方法調用,實現輸入圓盤數,打印移動的過程

def move(n,a,b,c):
  if n==1:
    print(a,'-->',c)
  else:
    move(n-1,a,c,b)  #將前n-1個盤子從a移動到b上
    move(1,a,b,c)   #將最底下的最后一個盤子從a移動到c上
    move(n-1,b,a,c)  #將b上的n-1個盤子移動到c上
move(3,'A','B','C')

程序執行的結果:

A --> C
A --> B
C --> B
A --> C
B --> A
B --> C
A --> C

程序分析:

涉及到遞歸函數,理解起來會容易凌亂,我們以3個盤子為例,進行執行步驟分析

(3,A,B,C)       
->move(2,A,C,B)
        ->move(1,A,B,C)   A->C
        ->move(1,A,C,B)   A->B
        ->move(1,C,A,B)   C->B
->move(1,A,B,C)             
                 A->C
->move(2,B,A,C)
        ->move(1,B,C,A)   B->A
        ->move(1,B,A,C)   B->C
        ->move(1,A,B,C)   A->C

更多關于Python相關內容感興趣的讀者可查看本站專題:《Python數據結構與算法教程》、《Python加密解密算法與技巧總結》、《Python編碼操作技巧總結》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經典教程》

希望本文所述對大家Python程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

清远市| 精河县| 铜梁县| 红桥区| 嘉义市| 洛浦县| 花垣县| 遵化市| 拉萨市| 广灵县| 湘乡市| 中西区| 铁岭县| 公安县| 博白县| 岐山县| 山东| 闻喜县| 淮安市| 阳春市| 高碑店市| 始兴县| 潮州市| 青州市| 宁化县| 太湖县| 穆棱市| 怀来县| 湄潭县| 孟津县| 闻喜县| 远安县| 晋州市| 阳春市| 苗栗县| 盐边县| 镇赉县| 蒲城县| 凉山| 萝北县| 池州市|