Submission #1691973


Source Code Expand

#include <stdio.h>
#include <iostream>
#include <algorithm>
#include <memory.h>

using namespace std;
typedef long long LL;
const int maxn = 800005;

int ehead[maxn],ecnt=1,deg[maxn];
struct edge {
	int u,v,next;
}edg[maxn];
void add(int u,int v) {
	edg[++ecnt]=(edge){u,v,ehead[u]};
	ehead[u]=ecnt;deg[u]++;
	edg[++ecnt]=(edge){v,u,ehead[v]};
	ehead[v]=ecnt;deg[v]++;
}
int n,a[maxn],b[maxn],w[maxn],vis[maxn],ra,rb;

void Euler(int u)
{
	for (int &j=ehead[u];j;j=edg[j].next)
	if (!vis[j>>1]) {
		vis[j>>1]=true;
		int v=edg[j].v;Euler(v);
		if (u==v+n) w[v]=-1;
		if (v==u+n) w[u]=1;
	}
}
int main()
{
	#ifdef Amberframe
		freopen("agc018f.in","r",stdin);
		freopen("agc018f.out","w",stdout);
	#endif
	scanf("%d",&n);
	for (int i=1;i<=n;i++) scanf("%d",&a[i]);
	for (int i=1;i<=n;i++) scanf("%d",&b[i]);
	for (int i=1;i<=n;i++) if (a[i]!=-1) add(i,a[i]);else ra=i;
	for (int i=1;i<=n;i++) if (b[i]!=-1) add(i+n,b[i]+n);else rb=i+n;
	add(0,ra);add(0,rb);
	for (int i=1;i<=n;i++)
		if ((deg[i]&1)!=(deg[i+n]&1)) {puts("IMPOSSIBLE");return 0;}
	puts("POSSIBLE");
	for (int i=1;i<=n;i++) if (deg[i]&1) add(i,i+n);
	Euler(0);for (int i=1;i<=n;i++) printf("%d ",w[i]);
	return 0;
}

Submission Info

Submission Time
Task F - Two Trees
User Amberframe
Language C++14 (GCC 5.4.1)
Score 1700
Code Size 1227 Byte
Status AC
Exec Time 76 ms
Memory 31488 KB

Compile Error

./Main.cpp: In function ‘int main()’:
./Main.cpp:38:16: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d",&n);
                ^
./Main.cpp:39:42: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
  for (int i=1;i<=n;i++) scanf("%d",&a[i]);
                                          ^
./Main.cpp:40:42: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
  for (int i=1;i<=n;i++) scanf("%d",&b[i]);
                                          ^

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 4 ms 12544 KB
sample_02.txt AC 3 ms 10496 KB
sample_03.txt AC 4 ms 12544 KB
subtask_1_01.txt AC 3 ms 10496 KB
subtask_1_02.txt AC 3 ms 10496 KB
subtask_1_03.txt AC 16 ms 12544 KB
subtask_1_04.txt AC 40 ms 23936 KB
subtask_1_05.txt AC 23 ms 16640 KB
subtask_1_06.txt AC 15 ms 14976 KB
subtask_1_07.txt AC 31 ms 17536 KB
subtask_1_08.txt AC 14 ms 12544 KB
subtask_1_09.txt AC 15 ms 12544 KB
subtask_1_10.txt AC 36 ms 23168 KB
subtask_1_11.txt AC 7 ms 10496 KB
subtask_1_12.txt AC 48 ms 27392 KB
subtask_1_13.txt AC 18 ms 12544 KB
subtask_1_14.txt AC 9 ms 13696 KB
subtask_1_15.txt AC 15 ms 12928 KB
subtask_1_16.txt AC 19 ms 12544 KB
subtask_1_17.txt AC 13 ms 12544 KB
subtask_1_18.txt AC 50 ms 30080 KB
subtask_1_19.txt AC 25 ms 16640 KB
subtask_1_20.txt AC 57 ms 30848 KB
subtask_1_21.txt AC 25 ms 16640 KB
subtask_1_22.txt AC 25 ms 16640 KB
subtask_1_23.txt AC 56 ms 30720 KB
subtask_1_24.txt AC 46 ms 22016 KB
subtask_1_25.txt AC 24 ms 16640 KB
subtask_1_26.txt AC 24 ms 16640 KB
subtask_1_27.txt AC 56 ms 30976 KB
subtask_1_28.txt AC 25 ms 16640 KB
subtask_1_29.txt AC 69 ms 30720 KB
subtask_1_30.txt AC 25 ms 16640 KB
subtask_1_31.txt AC 26 ms 16640 KB
subtask_1_32.txt AC 57 ms 30720 KB
subtask_1_33.txt AC 45 ms 22016 KB
subtask_1_34.txt AC 24 ms 16640 KB
subtask_1_35.txt AC 24 ms 16640 KB
subtask_1_36.txt AC 58 ms 30976 KB
subtask_1_37.txt AC 55 ms 30848 KB
subtask_1_38.txt AC 56 ms 30848 KB
subtask_1_39.txt AC 55 ms 30848 KB
subtask_1_40.txt AC 55 ms 30720 KB
subtask_1_41.txt AC 56 ms 30464 KB
subtask_1_42.txt AC 43 ms 31488 KB
subtask_1_43.txt AC 57 ms 30976 KB
subtask_1_44.txt AC 57 ms 30848 KB
subtask_1_45.txt AC 60 ms 30848 KB
subtask_1_46.txt AC 62 ms 30848 KB
subtask_1_47.txt AC 56 ms 30720 KB
subtask_1_48.txt AC 56 ms 30464 KB
subtask_1_49.txt AC 43 ms 31488 KB
subtask_1_50.txt AC 56 ms 30976 KB
subtask_1_51.txt AC 60 ms 30848 KB
subtask_1_52.txt AC 56 ms 30848 KB
subtask_1_53.txt AC 76 ms 30848 KB
subtask_1_54.txt AC 57 ms 30720 KB
subtask_1_55.txt AC 58 ms 30592 KB
subtask_1_56.txt AC 43 ms 31488 KB
subtask_1_57.txt AC 57 ms 30976 KB
subtask_1_58.txt AC 59 ms 30848 KB
subtask_1_59.txt AC 65 ms 30848 KB
subtask_1_60.txt AC 56 ms 30848 KB
subtask_1_61.txt AC 56 ms 30720 KB
subtask_1_62.txt AC 55 ms 30208 KB
subtask_1_63.txt AC 45 ms 31488 KB
subtask_1_64.txt AC 61 ms 30976 KB