首页 > 技术文章 > 汉诺塔

henuLiGang 2018-03-21 09:23 原文

汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着 64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。

现在蒜头君开始玩汉诺塔游戏, 他放了 n片黄金圆盘在第一根柱子上,从上到下依次编号为 1n, 1 号圆盘最小,n 号圆盘最大。蒜头君移动第 i 号圆盘的时候需要花费 i点体力。现在蒜头君想把圆盘全部移动到底 根柱子上,移动过程中蒜头君必须准守游戏规则。

现在蒜头君想知道他完成游戏的最小移动次数和最少消耗的体力。

输入格式

输入一个正整数 n(1n60) 表示黄金圆盘的个数

输出格式

一行输出 2 个数,表示最小移动次数和最小消耗的体力,中间用一个空格隔开。

样例输入1

2

样例输出1

3 4

样例输入2

3

样例输出2

7 11
package 计蒜客;

import java.util.Scanner;

public class 汉诺塔 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner scan=new Scanner(System.in);
        int n=scan.nextInt();
        long[] arr=new long[n+1];
        arr[1]=1;
        for(int i=2;i<=n;i++){
            arr[i]=arr[i-1]+i+arr[i-1];
        }
        System.out.println(((long)Math.pow(2, n)-1)+" "+arr[n]);
    }

}

 

推荐阅读