分治法-汉诺塔

博客围绕汉诺塔游戏展开,介绍其问题描述,即有A、B、C三个塔座,圆盘初始都在A塔座。给出解决该问题的代码及运行结果,并进行算法分析,核心是把n盘移到目标柱,通过递归将1~n - 1盘先移到辅助柱,直至n = 1。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述
在汉诺塔游戏中,有三个分别命名为A、B、C得塔座,几个大小各不相同,从小到大一次编号得圆盘,每个原盘中间有一个小孔。最初,所有得圆盘都在A塔座上,其中最大得圆盘在最下面,然后是第二大,以此类推.
代码

package FenZi;

public class HanNuoTa {
	private static int count = 1;
    public static void main(String[] args) {
        moved(4, "第一根柱子", "第二根柱子", "第三根柱子");
    }
    
    /**
     * 
     * @param i  圆盘数量
     * @param a  圆盘初始所在塔座
     * @param b  圆盘将要移动到的塔座
     * @param c     辅助圆盘移动的塔座
     */
    public static void moved(int i,String a,String b,String c){
        if(i == 1){
            disPaly(1, a, b);
        }else{
            //将i-1根圆盘由A移动到C
            moved(i-1, a, c, b);
            //将圆盘i 由A移动到B
            disPaly(i, a, b);
            //将i-1根圆盘由C移动到A
            moved(i-1,c,b,a);
        }
    }
    
    public static void disPaly(int i,String a,String b){
        System.out.println("第"+count+"步:移动第"+i+"个塔从"+a+"到"+b);
        count++;
    }
}

运行结果

第1步:移动第1个塔从第一根柱子到第三根柱子
第2步:移动第2个塔从第一根柱子到第二根柱子
第3步:移动第1个塔从第三根柱子到第二根柱子
第4步:移动第3个塔从第一根柱子到第三根柱子
第5步:移动第1个塔从第二根柱子到第一根柱子
第6步:移动第2个塔从第二根柱子到第三根柱子
第7步:移动第1个塔从第一根柱子到第三根柱子
第8步:移动第4个塔从第一根柱子到第二根柱子
第9步:移动第1个塔从第三根柱子到第二根柱子
第10步:移动第2个塔从第三根柱子到第一根柱子
第11步:移动第1个塔从第二根柱子到第一根柱子
第12步:移动第3个塔从第三根柱子到第二根柱子
第13步:移动第1个塔从第一根柱子到第三根柱子
第14步:移动第2个塔从第一根柱子到第二根柱子
第15步:移动第1个塔从第三根柱子到第二根柱子

算法分析
在这里插入图片描述
把n盘移到目标柱上
1.先1~n-1盘都移到C柱上,用B做辅助柱
2.把n盘移到B柱上
3.把1~n-1盘移到B柱上,用A做辅助柱
任何数量的盘,都等于先将1~n-1移动到辅助柱上,然后移动n盘。这种递归,直到n=1。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值