https://www.luogu.org/jump/atcoder/2370

题解

答案不是\(2^{2m}\)因为每轮的第一次取球可能会不够。

我们可以设\(dp[i][j]\)表示到了第\(i\)轮,当前白球有\(j\)个的方案数。

转移的话枚举下一次拿球的方案。

白白:\((i,j)->(i+1,j-1)\)

黑黑:\((i,j)->(i+1,j+1)\)

白黑:\((i,j)->(i+1,j)\)

黑白:\((i,j)->(i+1,j)\)

把每个状态放在二维平面上的话,我们其实是在统计本质不同的折线个数。

但是这样会算重。

所以我们需要让每条折线强制碰到底部。

那么我们在状态中记录一下是否碰到底部就行了。

代码

#include<bits/stdc++.h>
#define N 3002
using namespace std;
typedef long long ll;
const int mod=1e9+7;
ll dp[N][N][2];
int n,m;
inline void MOD(ll &x){x=x>=mod?x-mod:x;}
inline ll rd(){
ll x=0;char c=getchar();bool f=0;
while(!isdigit(c)){if(c=='-')f=1;c=getchar();}
while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return f?-x:x;
}
int main(){
n=rd();m=rd();
for(int i=1;i<=n;++i)dp[0][i][0]=1;
dp[0][0][1]=1;
for(int i=1;i<=m;++i){
for(int j=0;j<=n;++j)
for(int k=0;k<2;++k)if(dp[i-1][j][k]){
if(j){
MOD(dp[i][j-1][k|(j==1)]+=dp[i-1][j][k]);
MOD(dp[i][j][k|(j==1)]+=dp[i-1][j][k]);
}
if(j<n){
MOD(dp[i][j+1][k]+=dp[i-1][j][k]);
MOD(dp[i][j][k]+=dp[i-1][j][k]);
}
}
}
ll ans=0;
for(int i=0;i<=n;++i)MOD(ans+=dp[m][i][1]);
cout<<ans;
return 0;
}

最新文章

  1. 根据采购/销售订单创建STO/SO
  2. VMware共享目录设置
  3. typedef用法小结
  4. 一篇文章讲清楚android ImageView.ScaleType
  5. HDOJ 4252 A Famous City 单调栈
  6. android studio学习
  7. libvlc media player in C# (part 1)
  8. javaSocket与C通信
  9. apicloud ios 打包流程
  10. hexo工具介绍及使用方法
  11. Ext.NET加入自定义验证JS函数
  12. VimFaultException A specified parameter was not correct configSpec.guestId
  13. [MySQL] 测试where group by order by的索引问题
  14. 用于文本分类的多层注意力模型(Hierachical Attention Nerworks)
  15. Python中time模块详解(转)
  16. (使用STL中的数据结构进行编程7.3.15)UVA 630 Anagrams (II)(求一个单词在字典中出现的次数)
  17. CBrother异或加密与C++异或加密函数
  18. Python3 元组Tuple(十二)
  19. 阻止按下backspace键造成页面回退相像
  20. Ubuntu 16.04LTS 更新清华源

热门文章

  1. [Web 前端] 026 jQuery 初探
  2. [转帖]解决K8S 安装只有 一直提示:kernel:unregister_netdevice: waiting for eth0 to become free. Usage count = 1 的方法
  3. [AGC040B]Two Contests
  4. 替换url不刷新页面
  5. steps 步骤条、时间轴
  6. loli的测试-2018.12.9
  7. C++的同名属性(没有虚拟属性)、同名普通函数、同名静态函数(没有虚拟静态函数),是否被覆盖
  8. UITextField 文本框 只能输入数字 且保留2位小数 实现
  9. javascript中跨域问题的解决方法汇总
  10. JS 的 Array 和String 常混淆方法