作者简介:一名大一在校生
个人主页:月亮嚼成星~
个人WeChat:yx1552029968
系列专栏:Java SE基础
每日一句:奔跑不单是一种能力,更是一种态度,决定你人生高度的态度。
目录
🐳一、汉诺塔简介:
汉诺塔(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个盘子的时候: