亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java遞歸來實現(xiàn)漢諾塔游戲,注釋詳細

 更新時間:2021年11月25日 17:17:39   作者:鋼鐵的面條  
這篇文章介紹了Java遞歸來實現(xiàn)漢諾塔游戲的方法,文中的代碼注釋介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

我們很容易能想到,可以用遞歸來實現(xiàn)漢諾塔游戲。因為要將n(n>1)個盤子從“源”柱子移到“目標”柱子,我們要先把n-1個盤子從“源”柱子移到“輔助”柱子上,然后把最底下那一個盤子移到目標柱子上,最后把“輔助柱”上的n-1個盤子移動到目標柱子上。n==1時直接移到目標柱上,也是遞歸的出口。

有了以上思路的鋪墊,就可以開始實現(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時直接移到目標柱上
            System.out.printf("把一個盤子從%s柱子上移動到%s柱子上\n",source,target);
            hanoiCalledCount++;//計數(shù)器加一
        }else{
            //先把n-1個盤子從“源”柱子移到“輔助”柱子上
            hanoi(n-1,source,assist,target);
            //把最底下那一個盤子移到目標柱子上
            System.out.printf("把一個盤子從%s柱子上移動到%s柱子上\n",source,target);
            hanoiCalledCount++;//計數(shù)器加一
            //把“輔助柱”上的n-1個盤子移動到目標柱子上
            hanoi(n-1,assist,target,source);
        }
    }
}

運行結果如下,大家可以嘗試驗證一下是否正確。

當n==2時,要操作3次

當n==3時,要操作7次

當n==4時,要操作15次

相信大家已經(jīng)猜出規(guī)律了,操作次數(shù)==n^2-1

可見,隨著盤子個數(shù)n的增加,操作次數(shù)以n^2增加,所以,自己玩漢諾塔游戲的是時候建議數(shù)字不要超過20。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Java 程序內部是如何執(zhí)行的?

    Java 程序內部是如何執(zhí)行的?

    這篇文章主要介紹了Java 程序內部是如何執(zhí)行的,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • SpringBoot+Jpa項目配置雙數(shù)據(jù)源的實現(xiàn)

    SpringBoot+Jpa項目配置雙數(shù)據(jù)源的實現(xiàn)

    本文主要介紹了SpringBoot+Jpa項目配置雙數(shù)據(jù)庫源的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • SpringBoot基于Mybatis-Plus自動代碼生成

    SpringBoot基于Mybatis-Plus自動代碼生成

    這篇文章主要介紹了SpringBoot基于Mybatis-Plus自動代碼生成,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • Map與JavaBean相互轉換的工具類?

    Map與JavaBean相互轉換的工具類?

    這篇文章主要介紹了Map與JavaBean相互轉換的工具類,在做導入的時候,遇到了需要將map對象轉化?成javabean的問題,也就是說,不清楚javabean的內部字段排列,只知道m(xù)ap的?key代表javabean的字段名,value代表值,需要的朋友可以參考下
    2022-02-02
  • Java Benchmark 基準測試的實例詳解

    Java Benchmark 基準測試的實例詳解

    這篇文章主要介紹了Java Benchmark 基準測試的實例詳解的相關資料,這里提供實例幫助大家學習理解這部分內容,需要的朋友可以參考下
    2017-08-08
  • JSP 獲取spring容器中bean的兩種方法總結

    JSP 獲取spring容器中bean的兩種方法總結

    這篇文章主要介紹了JSP 獲取spring容器中bean的方法總結的相關資料,需要的朋友可以參考下
    2017-05-05
  • 解決Android Studio安裝后運行出錯dose not...和Internal error...

    解決Android Studio安裝后運行出錯dose not...和Internal error...

    這篇文章主要介紹了解決Android Studio安裝后運行出錯dose not...和Internal error...的相關資料,需要的朋友可以參考下
    2017-03-03
  • java 中createStatement()方法的實例詳解

    java 中createStatement()方法的實例詳解

    這篇文章主要介紹了java 中createStatement()方法的實例詳解的相關資料,需要的朋友可以參考下
    2017-06-06
  • @ComponentScan注解用法之包路徑占位符解析

    @ComponentScan注解用法之包路徑占位符解析

    這篇文章主要介紹了@ComponentScan注解用法之包路徑占位符解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • eclipse啟動一個Springboot項目

    eclipse啟動一個Springboot項目

    本文主要介紹了eclipse啟動一個Springboot項目,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08

最新評論