• 【Java SE】汉诺塔问题


     

    96fded2715d54a1a9dbf8d591b0f6cc6.png作者简介:一名大一在校生 

    1dcdea841dc84e5daf2868d121ca7b4e.png个人主页:月亮嚼成星~

    06594baba3894494a77f632d61a0a55d.png个人WeChat:yx1552029968

    cf768df40706413e9fef3a992ed367c8.png系列专栏:Java SE基础

    39190fda869b4100bc23b9d7a235d91c.png每日一句:奔跑不单是一种能力,更是一种态度,决定你人生高度的态度。

    目录

    🐳一、汉诺塔简介:

    🐳 二:汉诺塔问题思路:

    🐳代码实现:

    🐳运行结果:


    🐳一、汉诺塔简介:

    汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
    在这里插入图片描述

     🐳二:汉诺塔问题思路:

    在移动的过程中要保证大盘在小盘的下面,目标是把第一个柱子上的圆盘都按规律移动到第三个柱子上。

    当A柱上只有一个圆盘的时候,直接从A移动到C柱

      

     当A柱上有2个圆盘的时候,先把最上面的圆盘移动到B柱,再把A柱剩余的一个盘子移动到C柱,最后把B柱上的圆盘放到C盘即可完成。

     

     

    当A柱有3个圆盘的时候,先将最上面的一个盘子放到C柱,再把第二个盘子放到B柱,在把C柱的盘子放到B柱,然后把A柱的盘子放到C柱,再把B柱的上面的一个盘子放到A柱,然后把B柱的盘子放到C柱,最后把A柱的盘子放到C盘即可。如动图所示:在这里插入图片描述

    现在假设有n个盘子,(n>=2),我们把最上面的n-1个盘子看成一个整体,最下面的盘子就是第n个盘子为一个整体。

    步骤:1、先把n-1个盘子移到B上,C作为辅助,(此时,A是出发点,B是目标点,C是辅助点)

               2、把最大的盘子,也就是第n个盘子,直接放到C上

               3、再把B上的n-1个盘子放到C上,A作为辅助(此时,B是出发点,C是目标点,A是辅助点)

    🐳代码实现:

    1. public class Test {
    2. /**
    3. *
    4. * @param n 盘子的数量
    5. * @param pos1 出发位置
    6. * @param pos2 中转位置
    7. * @param pos3 目标位置
    8. */
    9. public static void hanio(int n,char pos1, char pos2,char pos3) {
    10. if(n == 1) {//如果就一个盘子,就直接把A柱的盘子放到C柱
    11. move(pos1,pos3);
    12. return;
    13. }
    14. //如果盘子大于1
    15. hanio(n-1,pos1,pos3,pos2);//先把n-1个盘子移到B上,C作为辅助,(此时,A是出发点,B是目标点,C是辅助点)
    16. move(pos1,pos3);//把最大的盘子,也就是第n个盘子,直接放到C上
    17. hanio(n-1,pos2,pos1,pos3);//再把B上的n-1个盘子放到C上,A作为辅助(此时,B是出发点,C是目标点,A是辅助点)
    18. }
    19. /**
    20. *
    21. * @param pos1 起始位置
    22. * @param pos2 目标位置
    23. */
    24. public static void move(char pos1,char pos2) {
    25. System.out.print ("盘子的移动路线为:"+pos1+" -> " + pos2+" ");
    26. System.out.println();
    27. }
    28. public static void main(String[] args) {
    29. hanio(3,'A','B','C');
    30. }
    31. }

    🐳运行结果:

    当为三个盘子的时候:

    当为4个盘子的时候:

  • 相关阅读:
    分享40个Python源代码总有一个是你想要的
    有没有想过 Java 中的 main 方法为什么一定要用public修饰
    借助AI分析哥斯拉木马原理与Tomcat回显链路挖掘
    前端面试(4)—— DOM事件的总结
    5步绘制软件开发流程图
    Python批量将Photoshop文件保存为图片
    python 绘制BA图, 绘制Bland-Altman, 两个连续变量的一致性分析
    Charles模拟弱网
    SpringBoot-32-shiro整合mybatis
    猿创征文 |【Ant Design Pro】使用ant design pro做为你的开发模板(五)去除无效代码,生成一个清晰的开发模板
  • 原文地址:https://blog.csdn.net/m0_67995737/article/details/126085395