20190710-漢諾塔演算法

来源:https://www.cnblogs.com/hyj691001/archive/2019/07/10/11167032.html
-Advertisement-
Play Games

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


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

關鍵點:

一次只能移動一個盤子
大盤不能重疊在小盤子上

當n=1的時候
1. 直接將1從X移動到Z

當n=2的時候
1. 將1從X移動到Y軸
2. 將2從X移動到Z軸
3. 將1從Y移動到Z軸

當n=3的時候
1. 將1從X移動到Z
2. 將2從X移動到Y
3. 將1從Z移動到Y
4. 將3從X移動到Z
5. 將1從Y移動到X
6. 將2從Y移動到Z
7. 將1從X移動到Z

當n=4的時候

當前挪動的盤子為1,挪動軌跡為x==>y
當前挪動的盤子為2,挪動軌跡為x==>z
當前挪動的盤子為1,挪動軌跡為y==>z
當前挪動的盤子為3,挪動軌跡為x==>y
當前挪動的盤子為1,挪動軌跡為z==>x
當前挪動的盤子為2,挪動軌跡為z==>y
當前挪動的盤子為1,挪動軌跡為x==>y
當前挪動的盤子為4,挪動軌跡為x==>z
當前挪動的盤子為1,挪動軌跡為y==>z
當前挪動的盤子為2,挪動軌跡為y==>x
當前挪動的盤子為1,挪動軌跡為z==>x
當前挪動的盤子為3,挪動軌跡為y==>z
當前挪動的盤子為1,挪動軌跡為x==>y
當前挪動的盤子為2,挪動軌跡為x==>z
當前挪動的盤子為1,挪動軌跡為y==>z

總結規律為:

要想移動n個盤子從X軸到Z軸需要經過如下三步:
1. 將n-1個盤子從X軸移動到Y軸
2. 將第n個盤子從X軸移動到Z軸
3. 將n-1個盤子從Y軸移動到Z軸

轉換為演算法
• 遞歸的結束條件:
• 當n=1的時候,直接將n移動到Z軸
• 遞歸條件:
1. 將n-1個盤子從X軸移動到Y軸
2. 將第n個盤子從X軸移動到Z軸
3. 將n-1個盤子從Y軸移動到Z軸

代碼

def hannota(n,x,y,z):
    if n ==1:
        print('%s->%s'%(x,z))#當n=1的時候,直接將n移動到z軸
    else:
        hannota(n-1,x,z,y)#將n-1個盤子從X軸移動到Y軸
        print('%s->%s'%(x,z))#將第n個盤子從X軸移動到Z軸
        hannota(n-1,y,x,z)#將n-1個盤子從Y軸移動到Z軸
hannota(3,'x','y','z')

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 作為一個自學Java的自動化專業211大學本科生,在學習和實踐過程中”趟了不少雷“,所以有志於建立一個適合同樣有熱情學習Java技術的參考“排雷手冊”。 最近在讀劉增輝老師所著的《MyBatis從入門到精通》一書,很有收穫,於是將自己學習的過程以博客形式輸出,如有錯誤,歡迎指正! 第1章 MyBat ...
  • 一、Java註釋 1.作用:不會編譯倒.class文件之中;增強可讀性 2.分類: (1)單行註釋(只註釋當前行):// (2)多行註釋: (3)javadoc註釋 註意: 這種註釋可以被一個工具提取解析生成一個幫助文檔,這個工具在C:\Program Files\Java\jdk1.8.0_211 ...
  • 以下是以項目的的形式就行運行驗證五個消息的運行順序及調用鏈的原理,裡面主要用到了遞歸調用。 本篇博客先給大家展示代碼,後面進行文字及圖片講解執行的順序 一、創建java項目springAOPModule 二、創建項目包結構如下: 三、創建目標方法UserService 四、創建執行介面及方法(Met ...
  • 三四百的併發量的防止超賣問題可以用資料庫的悲觀鎖和樂觀鎖。 悲觀鎖比樂觀鎖(失敗重試)效率更高。因為這和響應速度 衝突頻率 重試代價有關。。樂觀鎖的衝突頻率和重試太多。 ...
  • 一 Number(數字) 1.1 數字類型的創建 1.2 Number 類型轉換 python內置數學函數 #abs(x) 返回數字的絕對值,如abs(-10) 返回 10 # ceil(x) 返回數字的上入整數,如math.ceil(4.1) 返回 5 # cmp(x, y) 如果 x < y 返 ...
  • 至於為什麼要創建虛擬環境以及創建虛擬環境的好處,這裡就不過多的描述了。相信沒有踩過坑估計也不會想要創建虛擬環境! 現在python版本主要有python2.x 和python3.x,並且python3.x現在是不向下相容的,但是,大部分都沒什麼變化的,最重要的是python2.x已經不再更新,所以, ...
  • 問題描述: pip instal MySQL-python 出現如下錯誤: 運行環境: python 2.7.10 setuptools 41.0.1 pip 19.1 操作系統:Windows7 64位 解決辦法: 1) 安裝mysql connector, 可根據系統版本選擇安裝32位或64位的 ...
  • A:迴圈結構while語句的格式: B:執行流程: a:執行初始化語句 b:執行判斷條件語句,看其返回值是true還是false 如果是true,就繼續執行 如果是false,就結束迴圈 c:執行迴圈體語句; d:執行控制條件語句 e:回到B繼續。 a:執行初始化語句 b:執行判斷條件語句,看其返回 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...