Java遞歸來(lái)實(shí)現(xiàn)漢諾塔游戲,注釋詳細(xì)
我們很容易能想到,可以用遞歸來(lái)實(shí)現(xiàn)漢諾塔游戲。因?yàn)橐獙(n>1)個(gè)盤(pán)子從“源”柱子移到“目標(biāo)”柱子,我們要先把n-1個(gè)盤(pán)子從“源”柱子移到“輔助”柱子上,然后把最底下那一個(gè)盤(pán)子移到目標(biāo)柱子上,最后把“輔助柱”上的n-1個(gè)盤(pán)子移動(dòng)到目標(biāo)柱子上。n==1時(shí)直接移到目標(biāo)柱上,也是遞歸的出口。
有了以上思路的鋪墊,就可以開(kāi)始實(shí)現(xiàn)代碼了。
public class HanoiDemo {
public static int hanoiCalledCount = 0;//成員變量記錄操作次數(shù)
//漢諾塔游戲是一種二路遞歸
public static void main(String[] args) {
hanoi(3,"A","B","C");
System.out.println("執(zhí)行"+hanoiCalledCount+"步");
}
public static void hanoi(int n,String source,String target,String assist){
if(n<=0){
System.out.println("n要大于零");
}
if(n==1){//遞歸的出口,n==1時(shí)直接移到目標(biāo)柱上
System.out.printf("把一個(gè)盤(pán)子從%s柱子上移動(dòng)到%s柱子上\n",source,target);
hanoiCalledCount++;//計(jì)數(shù)器加一
}else{
//先把n-1個(gè)盤(pán)子從“源”柱子移到“輔助”柱子上
hanoi(n-1,source,assist,target);
//把最底下那一個(gè)盤(pán)子移到目標(biāo)柱子上
System.out.printf("把一個(gè)盤(pán)子從%s柱子上移動(dòng)到%s柱子上\n",source,target);
hanoiCalledCount++;//計(jì)數(shù)器加一
//把“輔助柱”上的n-1個(gè)盤(pán)子移動(dòng)到目標(biāo)柱子上
hanoi(n-1,assist,target,source);
}
}
}
運(yùn)行結(jié)果如下,大家可以嘗試驗(yàn)證一下是否正確。

當(dāng)n==2時(shí),要操作3次
當(dāng)n==3時(shí),要操作7次
當(dāng)n==4時(shí),要操作15次
相信大家已經(jīng)猜出規(guī)律了,操作次數(shù)==n^2-1
可見(jiàn),隨著盤(pán)子個(gè)數(shù)n的增加,操作次數(shù)以n^2增加,所以,自己玩漢諾塔游戲的是時(shí)候建議數(shù)字不要超過(guò)20。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot+Jpa項(xiàng)目配置雙數(shù)據(jù)源的實(shí)現(xiàn)
本文主要介紹了SpringBoot+Jpa項(xiàng)目配置雙數(shù)據(jù)庫(kù)源的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12
SpringBoot基于Mybatis-Plus自動(dòng)代碼生成
這篇文章主要介紹了SpringBoot基于Mybatis-Plus自動(dòng)代碼生成,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
Java Benchmark 基準(zhǔn)測(cè)試的實(shí)例詳解
這篇文章主要介紹了Java Benchmark 基準(zhǔn)測(cè)試的實(shí)例詳解的相關(guān)資料,這里提供實(shí)例幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08
JSP 獲取spring容器中bean的兩種方法總結(jié)
這篇文章主要介紹了JSP 獲取spring容器中bean的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-05-05
解決Android Studio安裝后運(yùn)行出錯(cuò)dose not...和Internal error...
這篇文章主要介紹了解決Android Studio安裝后運(yùn)行出錯(cuò)dose not...和Internal error...的相關(guān)資料,需要的朋友可以參考下2017-03-03
java 中createStatement()方法的實(shí)例詳解
這篇文章主要介紹了java 中createStatement()方法的實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06
eclipse啟動(dòng)一個(gè)Springboot項(xiàng)目
本文主要介紹了eclipse啟動(dòng)一個(gè)Springboot項(xiàng)目,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08

