[NOIP2007 普及组] Hanoi 双塔问题
题目描述
给定 A A A、 B B B、 C C C三根足够长的细柱,在 A A A柱上放有 2 n 2n 2n个中间有孔的圆盘,共有 n n n个不同的尺寸,每个尺寸都有两个相同的圆盘,注意这两个圆盘是不加区分的(下图为 n = 3 n=3 n=3的情形)。
现要将这些圆盘移到 C C C柱上,在移动过程中可放在 B B B柱上暂存。要求:
(1)每次只能移动一个圆盘;
(2) A A A、 B B B、 C C C三根细柱上的圆盘都要保持上小下大的顺序;
任务:设 A n A_n An为 2 n 2n 2n个圆盘完成上述任务所需的最少移动次数,对于输入的 n n n,输出 A n A_n An。
输入格式
一个正整数 n n n,表示在 A A A柱上放有 2 n 2n 2n个圆盘。
输出格式
一个正整数, 为完成上述任务所需的最少移动次数 A n A_n An。
样例 #1
样例输入 #1
1
样例输出 #1
2
样例 #2
样例输入 #2
2
样例输出 #2
6
提示
【限制】
对于 50 % 50\% 50%的数据, 1 ≤ n ≤ 25 1 \le n \le 25 1≤n≤25
对于 100 % 100\% 100%的数据, 1 ≤ n ≤ 200 1 \le n \le 200 1≤n≤200
【提示】
设法建立 A n A_n An与 A n − 1 A_{n-1} An−1的递推关系式。
分析:
这个题直接套公式就行了:移动最少次数=2^(n+1)-2
代码(伪):
#include<bits/stdc++.h>
using namespace std;
long long n;
int main()
{
cin>>n;
long long s=pow(2,n+1);
s-=2;
cout<<s;
return 0;
}
结果:70分
咋办呢???
用 Python3 啊!!!
我去学了亿下之后,终于把输入输出学废了。
但是2的x次方怎么求呢?百度一下
代码终于能写出来了~~~
代码(真):
n=int(input())//输入
print(2**(n+1)-2)//直接输出
(原谅我不会注释)
结束啦~~~