欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2021年09月26日 15:23:41   作者:愛內(nèi)卷的王同學  
漢諾塔,傳說神在創(chuàng)造世界的時候做了三根金剛石柱子,并在一個教塔里留下了三根金剛石棒,第一根上面從上到下套著64個按從小到大排列的金盤,神命令廟里的眾僧將它們一個個地從這根金剛石棒搬到另一根金剛石棒上,大盤不能放在小盤上。最后64個金盤仍然要按從小到大排列

最適合菜鳥的漢諾塔講解

問題引入

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

hz2Bfs.jpg

讓我們先從小事入手。

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

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

a 柱上面只有一個圓盤時

hz6FJI.jpg

只有這一種走法

a柱上有兩個圓盤時

hzcQBD.jpg

a柱上有三個圓盤時

hz29wF.jpg

a柱上有四個圓盤時

hzRc8A.jpg

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

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

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

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

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

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

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

用遞歸解決問題

上面我們已經(jīng)強調(diào)過了他們共性的部分是可以外包給下一級的

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

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

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

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

函數(shù)創(chuàng)建

根據(jù)我們分析出的漢諾塔特性就可以創(chuàng)建出我們需要的遞歸函數(shù),我們發(fā)現(xiàn),在外包的時候還是有一些細微的問題需要注意的

比如

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

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

落實到代碼上就是

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);
}

思維圖

hzTKTx.jpg

到此這篇關(guān)于Java手把手必會的實例漢諾塔講解練習的文章就介紹到這了,更多相關(guān)Java 漢諾塔 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java Spring @Autowired的這些騷操作,你都知道嗎

    Java Spring @Autowired的這些騷操作,你都知道嗎

    這篇文章主要介紹了徹底搞明白Spring中的自動裝配和Autowired注解的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-09-09
  • Java中synchronized鎖升級的過程

    Java中synchronized鎖升級的過程

    本文主要介紹了Java中synchronized鎖升級的過程,synchronized相對于早期的synchronized做出了優(yōu)化,從以前的加鎖就是重量級鎖優(yōu)化成了有一個鎖升級的過,下文詳細內(nèi)容需要的小伙伴可以參考一下
    2022-05-05
  • java實現(xiàn)畫圖板功能

    java實現(xiàn)畫圖板功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)畫圖板功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Spring Boot Feign服務(wù)調(diào)用之間帶token問題

    Spring Boot Feign服務(wù)調(diào)用之間帶token問題

    這篇文章主要介紹了Spring Boot Feign服務(wù)調(diào)用之間帶token的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 解決java.lang.ClassCastException的java類型轉(zhuǎn)換異常的問題

    解決java.lang.ClassCastException的java類型轉(zhuǎn)換異常的問題

    這篇文章主要介紹了解決java.lang.ClassCastException的java類型轉(zhuǎn)換異常的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Java接入通義千問的簡單方法示例

    Java接入通義千問的簡單方法示例

    ? 通義千問是阿里云開發(fā)的大語言模型(Large language Model )LLM,旨在提供廣泛的知識和普適性,可以理解和回答各領(lǐng)域中的問題,這篇文章主要給大家介紹了關(guān)于Java接入通義千問的簡單方法,需要的朋友可以參考下
    2024-02-02
  • Java設(shè)計模式之享元模式

    Java設(shè)計模式之享元模式

    這篇文章主要為大家詳細介紹了Java設(shè)計模式之享元模式的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • 基于SpringMVC對接前端參數(shù)注解

    基于SpringMVC對接前端參數(shù)注解

    這篇文章主要介紹了基于SpringMVC對接前端參數(shù)注解的使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • java如何給對象按照字符串屬性進行排序

    java如何給對象按照字符串屬性進行排序

    這篇文章主要介紹了java如何給對象按照字符串屬性進行排序,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 使用Java打印數(shù)字組成的魔方陣及字符組成的鉆石圖形

    使用Java打印數(shù)字組成的魔方陣及字符組成的鉆石圖形

    這篇文章主要介紹了使用Java打印數(shù)字組成的魔方陣及字符組成的鉆石圖形,可作為一些CLI程序界面的基礎(chǔ)部分,需要的朋友可以參考下
    2016-03-03

最新評論