专栏文章

abc312D

个人记录参与者 1已保存评论 0

文章操作

快速查看文章及其快照的属性,并进行相关操作。

当前评论
0 条
当前快照
1 份
快照标识符
@miprogn0
此快照首次捕获于
2025/12/03 16:50
3 个月前
此快照最后确认于
2025/12/03 16:50
3 个月前
查看原文
CPP
#include<bits/stdc++.h>
using namespace std;
long long read(){
	long long x=0,f=1;
	char ch=getchar();
	while(ch<'0'||ch>'9'){
		if(ch=='-'){
			f=-1;
		}
		ch=getchar();
	}
	while(ch>='0'&&ch<='9'){
		x=(x<<1)+(x<<3)+(ch^48);
		ch=getchar();
	}
	return x*f;
}
void write(long long x){
	if(x<0){
		putchar('-');
		x=-x;
	}
	if(x>9){
		write(x/10);
	}
	putchar(x%10+'0');
	return ;
}
int f[3005][6005];
int main(){
//	freopen(".in","r",stdin);
//	freopen(".out","w",stdout);
    string s;//)-1, (+1
    cin>>s;
    int n=s.size();
    s=' '+s;
    f[0][3003]=1;
    for(int i=1;i<=n;i++){
		if(s[i]==')'){
			for(int j=3003;j<=6000;j++){
				if(f[i-1][j]){
					f[i][j-1]+=f[i-1][j];
					f[i][j-1]%=998244353;
				}
			}
		}
		if(s[i]=='('){
			for(int j=3003;j<=6000;j++){
				if(f[i-1][j]){
					f[i][j+1]+=f[i-1][j];
					f[i][j+1]%=998244353;
				}
			}
		}
		if(s[i]=='?'){
			for(int j=3003;j<=6000;j++){
				if(f[i-1][j]){
					f[i][j+1]+=f[i-1][j];
					f[i][j+1]%=998244353;
					f[i][j-1]+=f[i-1][j];
					f[i][j-1]%=998244353;
				}
			}
		}
	}
	write(f[n][3003]%998244353);
	return 0;
}

评论

0 条评论,欢迎与作者交流。

正在加载评论...