一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java手把手必會的實例漢諾塔講解練習

Java手把手必會的實例漢諾塔講解練習

2022-01-19 10:47愛內卷的王同學 Java教程

漢諾塔,傳說神在創造世界的時候做了三根金剛石柱子,并在一個教塔里留下了三根金剛石棒,第一根上面從上到下套著64個按從小到大排列的金盤,神命令廟里的眾僧將它們一個個地從這根金剛石棒搬到另一根金剛石棒上,大盤不

最適合菜鳥的漢諾塔講解

 

問題引入

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

Java手把手必會的實例漢諾塔講解練習

讓我們先從小事入手。

標記漢諾塔的三根柱子分別為 a ,b ,c

標記漢諾塔上的圓盤分別為:1 ,2,3,4 …n

a 柱上面只有一個圓盤時

Java手把手必會的實例漢諾塔講解練習

只有這一種走法

a柱上有兩個圓盤時

Java手把手必會的實例漢諾塔講解練習

a柱上有三個圓盤時

Java手把手必會的實例漢諾塔講解練習

a柱上有四個圓盤時

Java手把手必會的實例漢諾塔講解練習

如上圖的實際操作過程可以很明顯的找到漢諾塔的操作規律:即分出來三個部分:

第一部分為 第一個紅框,用于將 前 n -1 個圓盤移到 b 柱

第二部分 用于將 最大的盤子移到 c 柱

第三部分為 第二個紅框,用于將 前 n - 1 個圓盤移到 c 柱

我們之所以這樣分為三個部分,是因為不管 a 柱上放了幾個盤子讓你移動 ,這三個部分是他們很明顯的共性,這便是規律所在。

(這樣的規律也是我們使用遞歸來解決漢諾塔問題的基礎。正是因為他們有共性的地方,我們才可以將其共性的地方外包給下一級。)

記住,千萬不要試圖去糾結 紅框 內部的圓盤具體移動方式,這是沒有任何規律可循的,想到死也想不出來的。

 

用遞歸解決問題

上面我們已經強調過了他們共性的部分是可以外包給下一級的

由此一來我們便可以將 n 個盤子的紅框部分 外包 給 下一級的 n-1

n-1 再將自己的紅框部分 外包 給 下一級的 n-2

n-2 同樣像上面那樣外包下去 直至 要動的盤子數為 1,程序便可以執行了

執行完之后,返回上一級執行 ,上一級結束再去上上級 , 如同多米諾骨牌一樣,n == 1 是引起垮塌的關鍵牌

 

函數創建

根據我們分析出的漢諾塔特性就可以創建出我們需要的遞歸函數,我們發現,在外包的時候還是有一些細微的問題需要注意的

比如

將 “4 個盤從a移到c” 中的 “將 3 個盤從 a 移到 b” 的操作 外包 給 “將 3 個盤從 a 移到 c” 時,雖然這是兩者共性

本質操作都是一樣的,移的都是相同數量的盤子,但是 他們移的目的柱是不一樣的,所以我們可以使柱子交換位置(注意這并不是真的交換,這是通過函數參數位置的改變來實現) 總而言之,就是一句話,將 “將 3 個盤從 a 移到 b” 中的 b 柱強行視為 c 柱,通過函數傳參就可以實現這種效果。

落實到代碼上就是

h(int n,char a,char b,char c) {
  if(n == 1){
      System.out.println(a+"-->"+c);
  }
  h(n-1,a,c,b);
  System.out.println(a+"-->"+c);
  h(n-1,b,a,c);
}

 

思維圖

Java手把手必會的實例漢諾塔講解練習

到此這篇關于Java手把手必會的實例漢諾塔講解練習的文章就介紹到這了,更多相關Java 漢諾塔 內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/qq_54693675/article/details/120242495

延伸 · 閱讀

精彩推薦
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
主站蜘蛛池模板: 成人在线一区二区三区 | 日本视频一区在线观看免费 | 日韩欧美一区二区在线观看 | 网站色小妹 | 美女天天色 | 男生操女生漫画 | 日本视频高清免费观看xxx | 91精品国产9l久久久久 | 4444www免费看 | 亚洲爱v | 黄色大片网| 亚洲区视频在线观看 | 国产精品青青在线观看香蕉 | 国内小情侣一二三区在线视频 | 亚洲欧美乱 | 精品一区二区三区波多野结衣 | 天天干天天色综合网 | 四虎影视免费观看 | 欧美日韩亚洲国内综合网香蕉 | 海角社区在线视频 | 暖暖中国免费观看高清完整版 | 精品欧美一区二区精品久久 | 18美女光胸光屁屁洗澡 | 欧美最猛性xxxxx男男 | 99热这里只精品99re66 | 国外欧美一区另类中文字幕 | ass亚洲熟妇毛茸茸pics | 好大好深好舒服 | 爽爽影院免费观看 | 欧美成人午夜片一一在线观看 | 亚洲网色 | 日本三级欧美三级人妇英文 | 久久丫线这里只精品 | 男女天堂 | 亚洲骚图 | 欧美精品国产一区二区 | 激情六月丁香婷婷四房播 | 1024免费观看完整版在线播放 | 日韩首页| 国产91精品在线播放 | 国产成人v爽在线免播放观看 |