您的位置:首页 > 移动开发

AtCoder Regular Contest 059 F Unhappy Hacking

2018-07-15 10:55 507 查看

Description



题面

Solution

我们发现如果一个位置需要被退掉,那么是 \(0\) 或 \(1\) 都没有关系

于是我们想到把 \(0,1\) 归为一类

问题转化为每一次可以添加和删除一个 \(?\),求 \(n\) 次操作后最后长度变为 \(|S|\) 的方案数

我们最后可以把 \(?\) 对应成 \(S\),只需要把方案数除以一个 \(2^{|S|}\) 就行了

#include<bits/stdc++.h>
using namespace std;
const int N=5005,mod=1e9+7;
int n,f

,m;char s
;
int main(){
freopen("pp.in","r",stdin);
freopen("pp.out","w",stdout);
scanf("%d%s",&n,s+1);m=strlen(s+1);
f[0][0]=1;
for(int i=0;i<n;i++)
for(int j=0;j<=i;j++){
if(j)f[i+1][j-1]=(f[i+1][j-1]+f[i][j])%mod;
else f[i+1][j]=(f[i+1][j]+f[i][j])%mod;
f[i+1][j+1]=(f[i+1][j+1]+1ll*f[i][j]*2)%mod;
}
for(int i=1;i<=m;i++)f
[m]=1ll*f
[m]*500000004%mod;
printf("%d\n",f
[m]);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: