一、问题背景
汉诺塔问题是一个经典的问题。汉诺塔(Hanoi Tower),又称河内塔,源于印度一个古老传说。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,任何时候,在小圆盘上都不能放大圆盘,且在三根柱子之间一次只能移动一个圆盘。问应该如何操作?
二、问题分析
假设我们需要移动n个盘子,我们可以先将A柱上的前n-1个盘子借助C柱移动到B柱,再将A柱剩余的一个盘子移动到C柱,再将B柱上的n-1个盘子借助A柱移动到C柱。
三、代码实现
四、运行结果
五、代码分析
递归运行大致如上图,过程难以用文字叙述只能靠自己了。
值得注意的是,hanoi中的ABC并不是一直对应着A柱B柱C柱,而是随着递归的过程而不断变化的,以此来影响move中的打印,在博主的观察下发现参数ABC在对应着ACB,ABC循环变化,第一次调用该方法时一定对应ABC。
汉诺塔问题中的递归比较难理解希望大家可以自己画图进行理解,那么文章就到此结束咯。