您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)如何用Java遞歸來實現(xiàn)漢諾塔游戲,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
我們很容易能想到,可以用遞歸來實現(xiàn)漢諾塔游戲。因為要將n(n>1)個盤子從“源”柱子移到“目標(biāo)”柱子,我們要先把n-1個盤子從“源”柱子移到“輔助”柱子上,然后把最底下那一個盤子移到目標(biāo)柱子上,最后把“輔助柱”上的n-1個盤子移動到目標(biāo)柱子上。n==1時直接移到目標(biāo)柱上,也是遞歸的出口。
有了以上思路的鋪墊,就可以開始實現(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時直接移到目標(biāo)柱上 System.out.printf("把一個盤子從%s柱子上移動到%s柱子上\n",source,target); hanoiCalledCount++;//計數(shù)器加一 }else{ //先把n-1個盤子從“源”柱子移到“輔助”柱子上 hanoi(n-1,source,assist,target); //把最底下那一個盤子移到目標(biāo)柱子上 System.out.printf("把一個盤子從%s柱子上移動到%s柱子上\n",source,target); hanoiCalledCount++;//計數(shù)器加一 //把“輔助柱”上的n-1個盤子移動到目標(biāo)柱子上 hanoi(n-1,assist,target,source); } } }
運行結(jié)果如下,大家可以嘗試驗證一下是否正確。
當(dāng)n==2時,要操作3次
當(dāng)n==3時,要操作7次
當(dāng)n==4時,要操作15次
相信大家已經(jīng)猜出規(guī)律了,操作次數(shù)==n^2-1
可見,隨著盤子個數(shù)n的增加,操作次數(shù)以n^2增加,所以,自己玩漢諾塔游戲的是時候建議數(shù)字不要超過20。
看完上述內(nèi)容,你們對如何用Java遞歸來實現(xiàn)漢諾塔游戲有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。