QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#592818#9319. Bull Farmrevolutionary_oierWA 0ms4012kbC++144.6kb2024-09-27 08:24:092024-09-27 08:24:09

Judging History

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

  • [2024-09-27 08:24:09]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:4012kb
  • [2024-09-27 08:24:09]
  • 提交

answer

#include<bits/stdc++.h>
#define int long long 
using namespace std;

const int maxn=2e3+10;
const int maxm=2e6+10;
int t,n,L,q,cnt_,l,tt;
bool flag;
char x[maxn<<2];
int fa[maxn],cnt[2],ct[maxn],dfn[maxn],low[maxn],h[maxn],deg[maxn];
bool in[maxn];
int c[maxn][maxn],head[2][maxn];
bitset<maxn>a[maxn],b[maxn];
struct qu{
	int S,T,num,ans,op;
}o[maxm];
struct node{
	int u,v,nxt;
}e[2][maxm],g[maxm];
inline int decode(char x,char y){
	int p=0;
	p=(x-'0')*50+y-'0';
	return p;
}
inline bool cmp(qu nx,qu ny){return nx.num<ny.num;}
inline bool cmp1(qu nx,qu ny){return nx.op<ny.op;}
inline void ipt(){
	tt=0;
	if(flag&&t==399)scanf("%lld%lld%lld",&n,&L,&q);
	for(int i=1;i<=n;i++)b[i]=0,fa[i]=i,b[i][i]=1;
	for(int i=1;i<=L;i++){
		scanf("%s",x);
		for(int j=0;j<2*n;j+=2)c[i][j/2+1]=decode(x[j],x[j+1]);
	}
//	for(int i=1;i<=L;i++){
//		for(int j=1;j<=n;j++)printf("%lld ",c[i][j]);
//		printf("\n");
//	}
	for(int i=1;i<=q;i++){
		scanf("%s",x);
		o[i].S=decode(x[0],x[1]);
		o[i].T=decode(x[2],x[3]);
		o[i].num=decode(x[4],x[5]);
		o[i].op=i;
		if(o[i].num==0){
			if(o[i].S==o[i].T)o[i].ans=1;
			else o[i].ans=0; 
		}
		else o[i].ans=0;
	}
	sort(o+1,o+q+1,cmp);
}
inline void add0(int u,int v){
	e[0][++cnt[0]].v=v;
	e[0][cnt[0]].u=u;
	e[0][cnt[0]].nxt=head[0][u];
	head[0][u]=cnt[0];
}
inline int find(int x){
	if(fa[x]==x)return x;
	return fa[x]=find(fa[x]);
}
inline bool make_graph(int k){
	cnt[0]=0;
	for(int i=1;i<=n;i++)head[0][i]=0;
	for(int i=1;i<=cnt[1];i++){
		int u=find(fa[e[1][i].u]),v=find(fa[e[1][i].v]);
		if(u==v)continue;
		add0(u,v);
	}
	for(int i=1;i<=n;i++)ct[i]=0;
	for(int i=1;i<=n;i++)ct[c[k][i]]++;
	int r=0;
	for(int i=1;i<=n;i++){
		if(ct[i]>2)return false;
		if(ct[i]==2)++r;
	}
	if(r>1)return false;
	if(r==0){
		for(int i=1;i<=n;i++){
			int u=find(fa[i]),v=find(fa[c[k][i]]);
			if(u==v)continue;
			add0(u,v);
		}
//		printf("k1 = %lld\n",k);
	}
	else {
//		printf("k2 = %lld\n",k);
		int s,s1=-1,s2=-1;
		for(int i=1;i<=n;i++){
			if(ct[i]==0)s=i;
			else if(ct[i]==2)r=i; 
		}
		for(int i=1;i<=n;i++){
			if(c[k][i]==r){
				if(s1==-1)s1=i;
				else s2=i;
			}
		}
		int u=find(fa[s1]),v=find(fa[s]);
		if(u!=v)add0(u,v);
		u=find(fa[s2]),v=find(fa[s]);
		if(u!=v)add0(u,v);
	}
	return true;
}
stack<int>st;
inline void tarjan(int u){
	dfn[u]=low[u]=++tt;																																																																																																																																																				
	st.push(u);
	in[u]=true;
	for(int i=head[0][u];i;i=e[0][i].nxt){
		int v=find(fa[e[0][i].v]);
		if(!dfn[v]){
			tarjan(v);
			low[u]=min(low[v],low[u]);
		}
		else if(in[v])low[u]=min(low[v],low[u]);
	}
	if(low[u]==dfn[u]){
		int tmp;
		while(!st.empty()){
			tmp=st.top();
			st.pop();
			in[tmp]=false;
			fa[tmp]=u;
			if(u==tmp)break;
			b[u]|=b[tmp];
			b[tmp]=0;
		}
	}
}
inline void add1(int u,int v){
	e[1][++cnt[1]].v=v;
	e[1][cnt[1]].u=u;
	e[1][cnt[1]].nxt=head[1][u];
	head[1][u]=cnt[1];
}
inline void add(int u,int v){
	g[++cnt_].v=v;
	g[cnt_].u=u;
	g[cnt_].nxt=h[u];
	h[u]=cnt_;	
}
inline void repair_graph(){
	cnt[1]=cnt_=0;
	for(int i=1;i<=n;i++)h[i]=head[1][i]=0;
	for(int i=1;i<=cnt[0];i++){
		int u=find(fa[e[0][i].u]),v=find(fa[e[0][i].v]);
//		printf("just_revolutionary_oier\n");
		if(u==v)continue;
//		printf("just_revolutionary_oier\n");
		add1(u,v);
		add(v,u);
		deg[u]++;
	}
}
queue<int>yt;
inline void topo_sort(){
	for(int i=1;i<=n;i++)a[i]=0;
	for(int i=1;i<=n;i++){
		int u=find(fa[i]);
		if(in[u])continue;
		a[u]=b[u];
		if(deg[u]==0)yt.push(find(fa[u]));
	}
	while(!yt.empty()){
		int u=yt.front();
		yt.pop();
		for(int i=h[u];i;i=g[i].nxt){
			int v=find(fa[g[i].v]);
			if(in[v])continue;
			a[v]|=a[u];
			--deg[v];
			if(deg[v]==0){
				in[v]=true;
				yt.push(v);
			}
		}
	}
	for(int i=1;i<=n;i++)in[i]=false;
}
inline void query(int k){
	while(l<q+1){
		if(o[l].num==k){
			if(a[find(fa[o[l].S])][find(fa[o[l].T])])o[l].ans=1;
			else o[l].ans=0;
		}
		else if(o[l].num>k)break;
		++l;
	}
}
inline void solve(){
	l=1;
	for(int i=1;i<=L;i++){
		if(!make_graph(i)){
			query(i);
			continue;
		}
		tt=0;
		for(int j=1;j<=n;j++)dfn[j]=low[j]=0;
		for(int j=1;j<=n;j++){
			int u=find(fa[j]);
			if(!dfn[u])tarjan(u);
		}
		repair_graph();
		topo_sort(); 
		query(i);
//		for(int j=1;j<=n;j++)printf("%lld ",fa[j]);
//		printf("\n");
	}
	sort(o+1,o+q+1,cmp1);
	if(!flag)for(int i=1;i<=q;i++)printf("%lld",o[i].ans);
	if(!flag)printf("\n");
}
signed main(){
	scanf("%lld",&t);
	if(t==400)flag=true;
	while(t--){
		ipt();
		solve();
	}
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 0
Wrong Answer
time: 0ms
memory: 4012kb

input:

2
5 2 4
0305040201
0404040404
030300
020500
050102
020501
6 2 4
030603010601
010203060504
030202
060402
050602
060401

output:




result:

wrong answer 1st lines differ - expected: '1011', found: ''