Submission #1549476


Source Code Expand

#include <bits/stdc++.h>
#define N 200005
 
using namespace std;
typedef pair <int,int> P;
 
vector <int> vec[N];
int par[N],dep[N];
int pr[N],ng[N];
bool use[N];
int n;
 
int rev(int v)
{
	if(v>=n) return v-n;
	return v+n;
}
int dfs(int v,int d)
{
	dep[v]=d;
	int a=-1;
	for(int i=0;i<vec[v].size();i++)
	{
		int to=vec[v][i];
		int tg=dfs(to,d+1);
		if(tg!=-1)
		{
			if(a==-1) a=tg;
			else
			{
				//printf("%d %d\n",a,tg);
				pr[a]=tg;
				pr[tg]=a;
				a=-1;
			}
		}
	}
	if(a==-1) a=v;
	return a;
}
int LCA(int a,int b)
{
	while(a!=b)
	{
		if(dep[a]>dep[b]) swap(a,b);
		b=par[b];
	}
	return a;
}
int main()
{
	scanf("%d",&n);
	for(int i=0;i<2*n;i++)
	{
		int p;
		scanf("%d",&p);p--;
		if(p<0) p=2*n;
		else if(i>=n) p+=n;
		par[i]=p;
		vec[p].push_back(i);
	}
	for(int i=0;i<n;i++)
	{
		if(vec[i].size()%2!=vec[i+n].size()%2)
		{
			puts("IMPOSSIBLE");
			return 0;
		}
	}
	memset(pr,-1,sizeof(pr));
	dfs(2*n,0);
	for(int i=0;i<2*n;i++)
	{
		if(!use[i]&&pr[i]!=-1)
		{
			use[i]=true;
			int now=i;
			do
			{
				use[now]=true;
				int to=pr[now];
				int p=LCA(now,to);
				//if(now==i) printf("%d %d : %d %d\n",now,to,p,i);
				for(int j=now;j!=p;j=par[j]) ng[j]=1;
				for(int j=to;j!=p;j=par[j]) ng[j]=-1;
				now=rev(to);
			}while(now!=i);
		}
	}
	puts("POSSIBLE");
	for(int i=0;i<n;i++)
	{
		int ret=ng[i];
		for(int j=0;j<vec[i].size();j++)
		{
			int to=vec[i][j];
			ret-=ng[to];
		}
		if(i!=0) printf(" ");
		printf("%d",ret);
	}puts("");
	return 0;
}

Submission Info

Submission Time
Task F - Two Trees
User wcz111
Language C++14 (GCC 5.4.1)
Score 1700
Code Size 1576 Byte
Status AC
Exec Time 66 ms
Memory 13696 KB

Compile Error

./Main.cpp: In function ‘int main()’:
./Main.cpp:52:16: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d",&n);
                ^
./Main.cpp:56:17: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d",&p);p--;
                 ^

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 1700 / 1700
Status
AC × 3
AC × 70
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, sample_01.txt, sample_02.txt, sample_03.txt, subtask_1_01.txt, subtask_1_02.txt, subtask_1_03.txt, subtask_1_04.txt, subtask_1_05.txt, subtask_1_06.txt, subtask_1_07.txt, subtask_1_08.txt, subtask_1_09.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt, subtask_1_17.txt, subtask_1_18.txt, subtask_1_19.txt, subtask_1_20.txt, subtask_1_21.txt, subtask_1_22.txt, subtask_1_23.txt, subtask_1_24.txt, subtask_1_25.txt, subtask_1_26.txt, subtask_1_27.txt, subtask_1_28.txt, subtask_1_29.txt, subtask_1_30.txt, subtask_1_31.txt, subtask_1_32.txt, subtask_1_33.txt, subtask_1_34.txt, subtask_1_35.txt, subtask_1_36.txt, subtask_1_37.txt, subtask_1_38.txt, subtask_1_39.txt, subtask_1_40.txt, subtask_1_41.txt, subtask_1_42.txt, subtask_1_43.txt, subtask_1_44.txt, subtask_1_45.txt, subtask_1_46.txt, subtask_1_47.txt, subtask_1_48.txt, subtask_1_49.txt, subtask_1_50.txt, subtask_1_51.txt, subtask_1_52.txt, subtask_1_53.txt, subtask_1_54.txt, subtask_1_55.txt, subtask_1_56.txt, subtask_1_57.txt, subtask_1_58.txt, subtask_1_59.txt, subtask_1_60.txt, subtask_1_61.txt, subtask_1_62.txt, subtask_1_63.txt, subtask_1_64.txt
Case Name Status Exec Time Memory
sample_01.txt AC 3 ms 7040 KB
sample_02.txt AC 3 ms 6272 KB
sample_03.txt AC 3 ms 7040 KB
subtask_1_01.txt AC 3 ms 6272 KB
subtask_1_02.txt AC 3 ms 6272 KB
subtask_1_03.txt AC 22 ms 8448 KB
subtask_1_04.txt AC 41 ms 9984 KB
subtask_1_05.txt AC 32 ms 9600 KB
subtask_1_06.txt AC 16 ms 8192 KB
subtask_1_07.txt AC 40 ms 10624 KB
subtask_1_08.txt AC 13 ms 6780 KB
subtask_1_09.txt AC 19 ms 7936 KB
subtask_1_10.txt AC 35 ms 9472 KB
subtask_1_11.txt AC 10 ms 7040 KB
subtask_1_12.txt AC 50 ms 10496 KB
subtask_1_13.txt AC 26 ms 8832 KB
subtask_1_14.txt AC 9 ms 7680 KB
subtask_1_15.txt AC 18 ms 8576 KB
subtask_1_16.txt AC 19 ms 7288 KB
subtask_1_17.txt AC 16 ms 7552 KB
subtask_1_18.txt AC 48 ms 10496 KB
subtask_1_19.txt AC 36 ms 9984 KB
subtask_1_20.txt AC 57 ms 11008 KB
subtask_1_21.txt AC 36 ms 10496 KB
subtask_1_22.txt AC 35 ms 12416 KB
subtask_1_23.txt AC 59 ms 12928 KB
subtask_1_24.txt AC 59 ms 12160 KB
subtask_1_25.txt AC 22 ms 7416 KB
subtask_1_26.txt AC 31 ms 9084 KB
subtask_1_27.txt AC 52 ms 10752 KB
subtask_1_28.txt AC 36 ms 9984 KB
subtask_1_29.txt AC 57 ms 11008 KB
subtask_1_30.txt AC 36 ms 10368 KB
subtask_1_31.txt AC 35 ms 12416 KB
subtask_1_32.txt AC 59 ms 12160 KB
subtask_1_33.txt AC 66 ms 12288 KB
subtask_1_34.txt AC 22 ms 7416 KB
subtask_1_35.txt AC 31 ms 9084 KB
subtask_1_36.txt AC 53 ms 10752 KB
subtask_1_37.txt AC 57 ms 11008 KB
subtask_1_38.txt AC 58 ms 11136 KB
subtask_1_39.txt AC 58 ms 11392 KB
subtask_1_40.txt AC 58 ms 11904 KB
subtask_1_41.txt AC 61 ms 12800 KB
subtask_1_42.txt AC 34 ms 9464 KB
subtask_1_43.txt AC 54 ms 10752 KB
subtask_1_44.txt AC 57 ms 11008 KB
subtask_1_45.txt AC 57 ms 11136 KB
subtask_1_46.txt AC 58 ms 11392 KB
subtask_1_47.txt AC 59 ms 11776 KB
subtask_1_48.txt AC 63 ms 13696 KB
subtask_1_49.txt AC 34 ms 9464 KB
subtask_1_50.txt AC 54 ms 10752 KB
subtask_1_51.txt AC 58 ms 11008 KB
subtask_1_52.txt AC 57 ms 11136 KB
subtask_1_53.txt AC 58 ms 11392 KB
subtask_1_54.txt AC 58 ms 11648 KB
subtask_1_55.txt AC 60 ms 12288 KB
subtask_1_56.txt AC 34 ms 9464 KB
subtask_1_57.txt AC 53 ms 10752 KB
subtask_1_58.txt AC 57 ms 11008 KB
subtask_1_59.txt AC 57 ms 11136 KB
subtask_1_60.txt AC 58 ms 11392 KB
subtask_1_61.txt AC 58 ms 11776 KB
subtask_1_62.txt AC 61 ms 13184 KB
subtask_1_63.txt AC 33 ms 9464 KB
subtask_1_64.txt AC 53 ms 10752 KB