比赛 至少完成十道练习 评测结果 TTTEEEEEEE
题目名称 前缀和不小于零 最终得分 0
用户昵称 FFF团 运行时间 3.501 s
代码语言 C++ 内存使用 0.32 MiB
提交时间 2017-05-23 19:58:21
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
int p[2001],ans,n,m,a,b,t=1;
void xia_search(int cur,int num){
	p[cur]=num+p[cur-1];
	if(cur==2*n&&p[cur]>=0)ans++;
	if(num==1)a--;
	if(num==-1)b--;
	if(p[cur]<0)return ;
	if(a>0){
		xia_search(cur+1,1);
	    p[cur]=num+p[cur-1];
	    a++;
	}
	if(b>0){
		xia_search(cur+1,-1);
	    p[cur]=num+p[cur-1];
	    b++;
	}
	return ;
}
int main(){
	freopen("overzero.in","r",stdin);
	freopen("overzero.out","w",stdout);
	scanf("%d%d",&n,&m);
	for(int i=1;i<=m;i++){
		int te;
		scanf("%d",&te);
		t*=te;
	}
	a=n;b=n;
	xia_search(1,1);
	printf("%d",ans%t);
	return 0;
}