【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是辅助点)

🐳代码实现:

public class Test {
    /**
     *
     * @param n     盘子的数量
     * @param pos1  出发位置
     * @param pos2  中转位置
     * @param pos3  目标位置
     */
    public static void hanio(int n,char pos1, char pos2,char pos3) {
        if(n == 1) {//如果就一个盘子,就直接把A柱的盘子放到C柱
            move(pos1,pos3);
            return;
        }
        //如果盘子大于1
        hanio(n-1,pos1,pos3,pos2);//先把n-1个盘子移到B上,C作为辅助,(此时,A是出发点,B是目标点,C是辅助点)
        move(pos1,pos3);//把最大的盘子,也就是第n个盘子,直接放到C上
        hanio(n-1,pos2,pos1,pos3);//再把B上的n-1个盘子放到C上,A作为辅助(此时,B是出发点,C是目标点,A是辅助点)
    }

    /**
     *
     * @param pos1 起始位置
     * @param pos2 目标位置
     */

    public static void move(char pos1,char pos2) {
        System.out.print ("盘子的移动路线为:"+pos1+" -> " + pos2+" ");
        System.out.println();
    }


    public static void main(String[] args) {
        hanio(3,'A','B','C');

    }
}

🐳运行结果:

当为三个盘子的时候:

当为4个盘子的时候:

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

渴望力量的土狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值