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

Java 細致圖解帶你分析漢諾塔

 更新時間:2022年03月23日 11:21:30   作者:來自爪哇的bean  
漢諾塔問題是一個經(jīng)典的問題。漢諾塔(Hanoi Tower),又稱河內(nèi)塔,源于印度一個古老傳說。本文將用Java求解這一問題,感興趣的可以學(xué)習(xí)一下

一、漢諾塔問題來源

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

二、問題分析

從簡單問題開始

直接拿64個盤子來想,可能會比較難,我們可以先從1個盤子開始看,如下圖:

一個盤子

A -> C?

只有一個盤子情況下,我們可以直接將 A 柱子上面的盤子移到 C 柱子上

需要移動一次

兩個盤子

當(dāng)有兩個盤子時,我們也可以通過下面方式實現(xiàn):

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

需要移動3次

1.? A -> B

2.? A -> C

?3.? B -> C

?三個盤子

?當(dāng)有三個盤子時,移動步驟如下:

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

共需要移動7次?

?1.? A -> C

2.? A -> B

?3.? C -> B

4.? A -> C

?5.? B -> A

?6.? B -> C

?7.? A -> C

這就完成了3個盤子的移動

當(dāng)有 4 個盤子時,這個問題其實就已經(jīng)很復(fù)雜了

規(guī)律推導(dǎo)

1個盤子? ? ? 移動1次

2個盤子? ? ? 移動3次

3個盤子? ? ? 移動7次

……

N 個盤子? ? 移動 2^N - 1 次

那么64個盤子就是需要移動 2^64 - 1 次

三、解決問題

我們可以通過遞歸來解決這個問題,獲得正確的移動方式

如果有N個盤子該怎么移動呢?

整體思路

我們可以先將 N?- 1 個盤子從 A 柱借助 C 柱移動到 B 柱,再將 A 柱剩下的一個盤子移動到 C柱,然后將 B 柱上的 N - 1 個盤子借助 A 柱移動到 C 柱,就完成了所有柱子的移動(中間具體移動過程暫不討論)

上代碼

public static void hanoi(int num, String src, String help, String dest) {
    if (num == 1) {     // 只有一個盤子的時候直接移動
        System.out.print(src + "->" + dest + "  ");  // 將一個盤子從源柱子挪到目標柱子
    } else {
        hanoi(num - 1, src, dest, help);   // 將n - 1個盤子從源柱子借助目標柱子挪到輔助柱子
        System.out.print(src + "->" + dest + "  ");  // 將一個盤子從源柱子挪到目標柱子
        hanoi(num - 1, help, src, dest);  // 將輔助柱子上n - 1個盤子借助源柱子挪到目標柱子
    }
}
public static void main(String[] args) {
    hanoi(3, "A", "B", "C");
}

這段代碼中 src 是源柱子,help是輔助柱子,dest 是目標柱子

這是一個二路遞歸

運行結(jié)果:

?這就成功完成了盤子的移動

四、婆羅門能否完成大梵天的任務(wù)

移動 64 個盤子需要多長時間

在這里我們假設(shè)婆羅門的人都非常聰明,不需要思考就直接能知道正確的移動方法,移動一個盤子需要一秒鐘,一直不停的移

將2^64 - 1秒換算為年約為5849 4241 7355年(5849.42億年),而地球存在至今不過45億年,太陽系的預(yù)期壽命據(jù)說也就是數(shù)百億年。真的過了5849.42億年,不說太陽系和銀河系,至少地球上的一切生命,連同梵塔、廟宇等,都早已經(jīng)灰飛煙滅。

相關(guān)預(yù)言

有預(yù)言說,這件事完成時宇宙會在一瞬間閃電式毀滅。也有人相信婆羅門至今還在一刻不停地搬動著圓盤

計算機移動64個盤子需要多長時間 ?

我的電腦核心頻率為2.90GHz,也就是每秒鐘運算 29 億次,那么移動 2^64 - 1次需要的時間約為201年

到此這篇關(guān)于Java 細致圖解帶你分析漢諾塔的文章就介紹到這了,更多相關(guān)Java 漢諾塔內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 通過java生成讀取二維碼詳解

    通過java生成讀取二維碼詳解

    這篇文章主要介紹了java二維碼生成讀取詳解,二維碼再生活在無處不在,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,下面和小編一起來學(xué)習(xí)一下吧
    2019-05-05
  • Java  匿名內(nèi)部類詳解及實例代碼

    Java 匿名內(nèi)部類詳解及實例代碼

    這篇文章主要介紹了Java 匿名內(nèi)部類詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • IDEA取消SVN關(guān)聯(lián),再重新分享項目的操作

    IDEA取消SVN關(guān)聯(lián),再重新分享項目的操作

    這篇文章主要介紹了IDEA取消SVN關(guān)聯(lián),再重新分享項目的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • Java?CAS與Atomic原子操作核心原理詳解

    Java?CAS與Atomic原子操作核心原理詳解

    CAS(Compare?and?Swap)和Atomic原子操作是保證多線程并發(fā)安全的常用機制,能夠高效地實現(xiàn)對共享變量的安全訪問和修改,避免線程競爭導(dǎo)致的數(shù)據(jù)不一致和死鎖等問題。它們的應(yīng)用可以提高程序的并發(fā)性能和可維護性,是多線程編程中的重要工具
    2023-04-04
  • Spring自動注入失敗的解決方法

    Spring自動注入失敗的解決方法

    這篇文章主要介紹了Spring自動注入失敗的解決方法,幫助大家更好的理解和學(xué)習(xí)使用Spring框架,感興趣的朋友可以了解下
    2021-05-05
  • Spring Security 中細化權(quán)限粒度的方法

    Spring Security 中細化權(quán)限粒度的方法

    這篇文章主要介紹了Spring Security 中細化權(quán)限粒度的方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • 一文帶你深入理解Java?AbstractQueuedSynchronizer

    一文帶你深入理解Java?AbstractQueuedSynchronizer

    在并發(fā)編程中,鎖是一種保證線程安全的方式,這篇文章主要為大家介紹了AbstractQueuedSynchronizer(AQS)的數(shù)據(jù)結(jié)構(gòu)及實現(xiàn)原理,感興趣的小伙伴可以了解一下
    2023-07-07
  • 基于Column注解的columnDefinition用法

    基于Column注解的columnDefinition用法

    這篇文章主要介紹了Column注解的columnDefinition用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • 常用輸入字節(jié)流InputStream介紹

    常用輸入字節(jié)流InputStream介紹

    下面小編就為大家?guī)硪黄S幂斎胱止?jié)流InputStream介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Java后端中dto、vo、entity的區(qū)別淺析

    Java后端中dto、vo、entity的區(qū)別淺析

    這篇文章主要給大家介紹了關(guān)于Java后端中dto、vo、entity區(qū)別的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2023-01-01

最新評論