计蒜客习题:汉诺塔


问题描述

汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着 64 片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
现在蒜头君开始玩汉诺塔游戏, 他放了 n 片黄金圆盘在第一根柱子上,从上到下依次编号为 1−n, 1 号圆盘最小,n 号圆盘最大。蒜头君移动第 i 号圆盘的时候需要花费 i 点体力。现在蒜头君想把圆盘全部移动到底2 根柱子上,移动过程中蒜头君必须准守游戏规则。
现在蒜头君想知道他完成游戏的最小移动次数和最少消耗的体力。。
输入格式
输入一个正整数n(1≤n≤60) 表示黄金圆盘的个数
输出格式
一行输出 2 个数,表示最小移动次数和最小消耗的体力,中间用一个空格隔开。
样例输入
3
样例输出
7 11


AC代码

#include
#include
using namespace std;
long long int n,a[70]={0};
void pr(){
    a[0]=1;
    for(long long int i=1;i<61;i++)
    a[i]=a[i-1]*2;
}
long long int digui(long long int now){
    if(now==0) return 0;
    return digui(now-1)+a[n-now]*now;
}
int main(){
    scanf("%lld",&n);
    pr();
    long long int s1=a[n]-1;
    long long int s2=digui(n);
    printf("%lld %lld",s1,s2);
    return 0;
}

你可能感兴趣的:(算法竞赛刷题,#,搜索算法,计蒜客NOIP习题)