题目描述
汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。
大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着 64 片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上(可以借助第三根柱子做缓冲)。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
如下图所示是现代“山寨”版的该玩具。64 个圆盘太多了,所以减为 7 个,金刚石和黄金都以木头代替了......但道理是相同的。
据说完成大梵天的命令需要太多的移动次数,以至被认为完成之时就是世界末日!
你的任务是精确计算出到底需要移动多少次。
很明显,如果只有 2 个圆盘,需要移动 3 次。
圆盘数为 3,则需要移动 7 次。
那么 64 个呢?
思路解析
// 1层:1次
// 2层:3次
// 3层:7次
// 4层:15次
// 5层:31次
// 6层:63次
// 7层:127次
// 8层:255次
// 9层:511次
// 计算公式:f(x)=2^x-1
// subtract()方法,这个函数的作用是将大整数相减
解题代码
import java.math.BigInteger;
public class Main {
public static void main(String[] args) {
BigInteger a= BigInteger.valueOf(2);
BigInteger b= BigInteger.valueOf(1);
a=a.pow(64).subtract(b);
System.out.println(a);
}
}