QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#369208#9. 简单回路ZZZCompile Error//C++143.5kb2024-03-27 21:58:382024-03-27 21:58:38

Judging History

你现在查看的是最新测评结果

  • [2024-03-27 21:58:38]
  • 评测
  • [2024-03-27 21:58:38]
  • 提交

answer

#include <bits/stdc++.h>
#define clr(x) memset(x,0,sizeof (x))
#define For(i,a,b) for (int i=(a);i<=(b);i++)
#define Fod(i,b,a) for (int i=(b);i>=(a);i--)
#define fi first
#define se second
#define pb(x) push_back(x)
#define mp(x,y) make_pair(x,y)
using namespace std;
typedef long long LL;
typedef pair <int,int> pii;
LL read(){
	LL x=0,f=0;
	char ch=getchar();
	while (!isdigit(ch))
		f=ch=='-',ch=getchar();
	while (isdigit(ch))
		x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
	return f?-x:x;
}
const int N=1005,M=10,S=55,mod=1e9+7;
void Add(int &x,int y){
	if ((x+=y)>=mod)
		x-=mod;
}
int n,m;
int a[N];
void in_a(){
	int k=read(),x,y;
	while (k--)
		x=read(),y=read(),a[x]|=1<<y;
}
int id[N],val[S][M],scnt=0,can[S];
vector <pii> trans[S];
vector <int> opp[S];
void getmatch(int *s,int *p){
	static int st[M];
	int top=0;
	For(i,1,m)
		if (s[i]==1)
			st[++top]=i;
		else if (s[i]==-1)
			p[i]=st[top],p[st[top]]=i,top--;
}
void get_manacher() 
void get_trans(int x,int e){
	static int f[M],p[M],d[M],res[M],vis[M];
	clr(f),clr(p),clr(res),clr(vis);
	int *s=val[x];
	For(i,1,m-1)
		f[i]=e>>(i-1)&1;
	int zzy=0;
	For(i,1,m){
		d[i]=(s[i]!=0)+f[i-1]+f[i];
		if (s[i]!=0&&f[i-1]&&f[i])
			return;
		if (d[i])
			zzy|=1<<i;
	}
	getmatch(s,p);
	For(i,1,m){
		if (vis[i]||d[i]!=1)
			continue;
		int j=i;
		while (j==i||d[j]==2){
			int nxt=0;
			vis[j]=1;
			if (p[j]&&!vis[p[j]])
				nxt=p[j];
			else if (f[j-1]&&!vis[j-1])
				nxt=j-1;
			else if (f[j]&&!vis[j+1])
				nxt=j+1;
			if (!nxt)
				return;
			j=nxt;
		}
		vis[j]=1;
		res[min(i,j)]=1,res[max(i,j)]=-1;
	}
	For(i,1,m)
		if (d[i]&&!vis[i])
			return;
	int Res=0;
	Fod(i,m,1)
		Res=Res*3+res[i]+1;
	trans[x].pb(mp(id[Res],zzy));
}
int check_opposite(int *a,int *b){
	static int pa[M],pb[M],vis[M];
	clr(vis);
	For(i,1,m)
		if ((a[i]!=0)^(b[i]!=0))
			return 0;
	getmatch(a,pa),getmatch(b,pb);
	int cnt=0;
	For(i,1,m)
		if (a[i]!=0)
			cnt++;
	For(i,1,m)
		if (a[i]!=0){
			int x=i;
			For(t,1,cnt){
				vis[x]=1,x=(t&1?pa:pb)[x];
				if (t<cnt&&vis[x])
					return 0;
			}
			return 1;
		}
}
void getval(int m){
	static int tmp[M];
	int p3=pow(3,m);
	For(i,0,p3-1){
		clr(tmp);
		int t=i,s=0,flag=1,empty=1,Can=0;
		For(j,1,m){
			tmp[j]=t%3-1;
			if (s==1&&Can!=-1)
				Can|=1<<j;
			s+=tmp[j];
			if (s==1&&Can!=-1)
				Can|=1<<j;
			if (s>1)
				Can=-1;
			empty&=s==0;
			flag&=s>=0;
			t/=3;
		}
		flag&=s==0;
		flag&=!empty;
		if (flag){
			id[i]=++scnt;
			For(j,1,m)
				val[scnt][j]=tmp[j];
			can[scnt]=Can;
		}
	}
	For(i,1,scnt){
		For(e,0,(1<<(m-1))-1)
			get_trans(i,e);
		For(j,1,scnt)
			if (check_opposite(val[i],val[j]))
				opp[i].pb(j);
	}
}
int pre[N][S],suf[N][S];
int ans[N][M];
int main(){
	n=read(),m=read();
	in_a();
	getval(m);
	For(i,1,n){
		For(j,1,scnt){
			if (can[j]!=-1&&!(can[j]&a[i]))
				Add(pre[i][j],1);
			int v=pre[i-1][j];
			if (!v)
				continue;
			for (auto t : trans[j])
				if (!(t.se&a[i]))
					Add(pre[i][t.fi],v);
		}
	}
	Fod(i,n,1){
		For(j,1,scnt){
			if (can[j]!=-1&&!(can[j]&a[i]))
				Add(suf[i][j],1);
			int v=suf[i+1][j];
			if (!v)
				continue;
			for (auto t : trans[j])
				if (!(t.se&a[i]))
					Add(suf[i][t.fi],v);
		}
	}
	For(i,1,n-1)
		For(j,1,scnt)
			for (auto o : opp[j]){
				int v=(LL)pre[i][j]*suf[i+1][o]%mod;
				For(k,1,m)
					if (val[j][k]!=0)
						Add(ans[i][k],v);
			}
	int q=read();
	while (q--){
		int x=read(),y=read();
		printf("%d\n",ans[x][y]);
	}
	return 0;
}

Details

answer.code:46:1: error: expected initializer before ‘void’
   46 | void get_trans(int x,int e){
      | ^~~~
answer.code: In function ‘void getval(int)’:
answer.code:141:25: error: ‘get_trans’ was not declared in this scope
  141 |                         get_trans(i,e);
      |                         ^~~~~~~~~
answer.code: In function ‘int check_opposite(int*, int*)’:
answer.code:110:1: warning: control reaches end of non-void function [-Wreturn-type]
  110 | }
      | ^