NC16865. [NOI2000]青蛙过河
描述
大小各不相同的一队青蛙站在河左岸的石墩(记为A)上,要过到对岸的石墩(记为D)上去。河心有几片菏叶(分别记为Y1…Ym)和几个石墩(分别记为S1…Sn)。图示如下:
青蛙的站队和移动方法规则如下:
1. 每只青蛙只能站在荷叶、石墩,或者仅比它大一号的青蛙背上(统称为合法的落脚点);
2. 一只青蛙只有背上没有其它青蛙的时候才能够从一个落脚点跳到另一个落脚点;
3. 青蛙允许从左岸A直接跳到河心的石墩、荷叶和右岸的石墩D上,允许从河心的石墩和荷叶跳到右岸的石墩D上;
4. 青蛙在河心的石墩之间、荷叶之间以及石墩和荷叶之间可以来回跳动;
5. 青蛙在离开左岸石墩后,不能再返回左岸;到达右岸后,不能再跳回;
7. 荷叶不仅面积不大,而且负重能力也有限,至多只能有一只青蛙站在上面。
8. 每一步只能移动一只青蛙,并且移动后需要满足站队规则;
9. 在一开始的时候,青蛙均站在A上,最大的一只青蛙直接站在石墩上,而其它的青蛙依规则6站在比其大一号的青蛙的背上。
青蛙希望最终能够全部移动到D上,并完成站队。
设河心有m片荷叶和n个石墩,请求出这队青蛙至多有多少只,在满足站队和移动规则的前提下,能从A过到D。
输入描述
仅有两行,每一行仅包含一个整数和一个换行/回车符。第一行的数字为河心的石墩数n(0 ≤ N ≤ 25),第二行为荷叶数m(0 ≤ M ≤ 25)。
输出描述
仅包含一个数字和一个换行/回车符。该数字为在河心有n个石墩和m片荷叶时,最多能够过河的青蛙的只数。
示例1
输入:
1 1
输出:
4
JavaScript (V8 6.0.0) 解法, 执行用时: 9ms, 内存消耗: 5108K, 提交时间: 2020-05-22 10:13:25
var n = parseInt(readline())//荷叶1 var m = parseInt(readline())//石墩n var res = (m+1)*(1<<n); console.log(res)
C++11(clang++ 3.9) 解法, 执行用时: 4ms, 内存消耗: 492K, 提交时间: 2020-05-12 22:17:48
#include<bits/stdc++.h> using namespace std; int main(){ int n,m; cin>>n>>m; cout<<((m+1)*(1<<n)); }
C++14(g++5.4) 解法, 执行用时: 2ms, 内存消耗: 376K, 提交时间: 2020-05-12 19:10:21
#include<cstdio> int main(){ int x,y; scanf("%d%d",&x,&y); printf("%d",(y+1)*1<<x); }
Python3(3.5.2) 解法, 执行用时: 31ms, 内存消耗: 3432K, 提交时间: 2020-05-12 21:41:40
n=int(input()) m=int(input()) print((m+1)*2**n)