救救孩子!全RE什么鬼
查看原帖
救救孩子!全RE什么鬼
240060
林兔兔楼主2021/4/7 09:45
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int N=2e6+5;
long long n,m,p;
int cnt,t,tt,top;;
int start[N],next[N],y[N],book[N],book2[N],low[N],in[N],s[N];
int size[N],book3[N];
int tarjan(int x)
{
	t++;
	low[x]=book[x]=t; in[x]=1;
	top++;
	s[top]=x;
	for(int i=start[x];i!=0;i=next[i])
	{
		if(book[y[i]]==0)
		{
			tarjan(y[i]);
			low[x]=min(low[x],low[y[i]]);
		}
		else if(in[y[i]]==1)
			low[x]=min(low[x],book[y[i]]);
	}
	if(low[x]==book[x])
	{
		tt++;
		int yyy=-1;
		while(x!=yyy)
		{
			yyy=s[top--];
			book2[yyy]=tt;
			in[yyy]=0;
		}
	}
}
void add(int xx,int yy)
{
	cnt++;
	next[cnt]=start[xx];
	y[cnt]=yy;
	start[xx]=cnt;
}
int main()
{
	cin>>n>>m;
	int xx,yy,p,q;
	for(int i=1;i<=m;i++)
	{
		scanf("%d%d%d%d",&xx,&p,&yy,&q);
		if(p==0&&q==0)
		{
			add(xx+n,yy);
			add(yy+n,xx);
		}
		if(p==0&&q==1)
		{
			add(xx+n,yy+n);
			add(yy,xx);
		}
		if(p==1&&q==0)
		{
			add(xx,yy);
			add(yy+n,xx+n);
		}
		if(p==1&&q==1)
		{
			add(xx,yy+n);
			add(yy,xx+n);
		}
	}
	for(int i=1;i<=2*n;i++)
		if(book[i]==0)
			tarjan(i);
	for(int i=1;i<=n;i++){
		if(book2[i]==book2[i+n])
		{
			cout<<"IMPOSSIBLE"<<endl;
			return 0;
		}
	}
	cout<<"POSSIBLE"<<endl;
	for(int i=1;i<=n;i++)
	{
		printf("%d ",book2[i]>book2[i+n]);
	}
	return 0;
}
2021/4/7 09:45
加载中...