记录编号 596082 评测结果 AAAAAAAAAA
题目名称 体育课 最终得分 100
用户昵称 Gravatar健康铀 是否通过 通过
代码语言 C++ 运行时间 0.054 s
提交时间 2024-10-21 15:33:03 内存使用 4.77 MiB
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
long long n,m,ans,g[100010][15],f[100010][15],p,num;
string s;
int main(){
	freopen("sportk.in","r",stdin);
	freopen("sportk.out","w",stdout);
	cin>>n>>m;
	cin>>s;
	for(int i=0;i<=s.size()-1;i++){
        f[i+1][1]=f[i][1]+s[i]-'0';
		g[i][1]=f[i][1];
	}
	for(long long i=0;i<=s.size()-1;i++){
		for(int j=2;j<=m;j++){
		    g[i+1][j]+=g[i][j-1]+g[i][j];
			g[i+1][j]%=998244353;
			f[i+1][j]+=f[i][j]+f[i][j-1]*2+(s[i]-'0')*g[i][j-1];
			f[i+1][j]%=998244353;
		}
	}
	for(int j=1;j<=m;j++){
		ans+=f[s.size()][j];
		ans%=998244353;
	}
	cout<<ans;
	return 0;
}