当前位置:首页 » 《随便一记》 » 正文

java实现汉诺塔游戏(递归)(附超详细易懂注释)_m0_53653818的博客

22 人参与  2022年04月27日 10:49  分类 : 《随便一记》  评论

点击全文阅读


  1. 我们很容易能想到,可以用递归来实现汉诺塔游戏。因为要将n(n>1)个盘子从“源”柱子移到“目标”柱子,我们要先把n-1个盘子从“源”柱子移到“辅助”柱子上,然后把最底下那一个盘子移到目标柱子上,最后把“辅助柱”上的n-1个盘子移动到目标柱子上。n==1时直接移到目标柱上,也是递归的出口。
  2. 有了以上思路的铺垫,就可以开始实现代码了。
  3. public class HanoiDemo {
        public static int hanoiCalledCount = 0;//成员变量记录操作次数
    
        //汉诺塔游戏是一种二路递归
        public static void main(String[] args) {
            hanoi(3,"A","B","C");
            System.out.println("执行"+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++;//计数器加一
            }else{
                //先把n-1个盘子从“源”柱子移到“辅助”柱子上
                hanoi(n-1,source,assist,target);
                //把最底下那一个盘子移到目标柱子上
                System.out.printf("把一个盘子从%s柱子上移动到%s柱子上\n",source,target);
                hanoiCalledCount++;//计数器加一
                //把“辅助柱”上的n-1个盘子移动到目标柱子上
                hanoi(n-1,assist,target,source);
            }
        }
    }

    运行结果如下,大家可以尝试验证一下是否正确。

  4. 当n==2时,要操作3次

        当n==3时,要操作7次

        当n==4时,要操作15次

        相信大家已经猜出规律了,操作次数==n^2-1

        可见,随着盘子个数n的增加,操作次数以n^2增加,所以,自己玩汉诺塔游戏的是时候建议数字不要超过20。


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/39042.html

柱子  盘子  递归  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 完结文我在恐怖游戏开裁缝铺列表_完结文我在恐怖游戏开裁缝铺(林慕秋)
  • 全书免费谢清禾姜博诚_谢清禾姜博诚全书免费
  • 离婚后我收获真爱,前妻却快死了(秦落音陆轩),离婚后我收获真爱,前妻却快死了
  • 老公把上亿豪宅送养妹后,我把人和房都拆了(顾思思顾言洲)全书免费_(顾思思顾言洲)老公把上亿豪宅送养妹后,我把人和房都拆了后续(顾思思顾言洲)
  • 沈星悦傅时安_沈星悦傅时安
  • 离婚后,居然还能以旧换新?(陈汉李淼淼李思)全书浏览_离婚后,居然还能以旧换新?全书浏览
  • 完结文给女团主播狂刷百万反被骂穷逼,我反手送她队友出道列表_完结文给女团主播狂刷百万反被骂穷逼,我反手送她队友出道(秦薇)
  • 全书浏览老公将我第十个孩子送给情人后,我果断改嫁他绝嗣干爹(苏云遮盛炽)_老公将我第十个孩子送给情人后,我果断改嫁他绝嗣干爹(苏云遮盛炽)全书结局
  • 全文无边怨恨是她活下来的最大动力(江寒静顾榕赫)列表_全文无边怨恨是她活下来的最大动力
  • 全文爸爸死后,消失二十年的妈妈带着儿子回来跟我争家产(顾霆锋顾青卿)列表_全文爸爸死后,消失二十年的妈妈带着儿子回来跟我争家产
  • 霍晚清赵旭然_霍晚清赵旭然
  • 弟弟看的破茧时光沉淀后的深情相拥林悦苏然全书在线

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1