Submission #2238988


Source Code Expand

#include<iostream>
#include<cstdio>
#include<map>
#define MN 200000
using namespace std;
inline int read()
{
	int x=0,f=1;char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
	return x*f;
}
map<int,int>mp;
int now=0,n,a[MN+5],b[MN+5],cnt,head[MN+5],in[MN+5],out[MN+5],num=0,size[MN+5],s[MN+5];
inline int getfa(int x){return s[x]?s[x]=getfa(s[x]):x;}
inline void ins(int f,int t)
{
	if(getfa(f)!=getfa(t))
		size[getfa(t)]+=size[getfa(f)],s[getfa(f)]=getfa(t);
	++in[t];++out[f];++cnt;
}
int main()
{
	n=read();
	for(int i=1;i<=n;++i) 
	{
		a[i]=read(),now^=a[i];
		if(!mp[a[i]]) mp[a[i]]=++num;
	}
	for(int i=1;i<=n;++i)
	{
		b[i]=read();
		if(!mp[b[i]]) mp[b[i]]=++num;	
	}
	if(!mp[now]) mp[now]=++num;++in[mp[now]];
	for(int i=1;i<=num;++i) size[i]=1;
	for(int i=1;i<=n;++i) if(a[i]!=b[i]) ins(mp[b[i]],mp[a[i]]);
	int difnum=0;
	for(int i=1;i<=num;++i) 
		if(out[i]>in[i]||in[i]+1<out[i]) return 0*puts("-1");
		else if(out[i]!=in[i]) ++difnum;
	if(difnum>1) return 0*puts("-1");
	for(int i=1;i<=num;++i) if(getfa(i)==i)
	{	
		if(size[i]==1) cnt+=(mp[now]==i);
		else ++cnt;
	}
	printf("%d",cnt-1);
	return 0;
}

Submission Info

Submission Time
Task D - XOR Replace
User FallDream
Language C++14 (GCC 5.4.1)
Score 1000
Code Size 1242 Byte
Status AC
Exec Time 134 ms
Memory 8832 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 1000 / 1000
Status
AC × 4
AC × 74
Set Name Test Cases
Sample 0_00.txt, 0_01.txt, 0_02.txt, 0_03.txt
All 0_00.txt, 0_01.txt, 0_02.txt, 0_03.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt, 1_20.txt, 1_21.txt, 1_22.txt, 1_23.txt, 1_24.txt, 1_25.txt, 1_26.txt, 1_27.txt, 1_28.txt, 1_29.txt, 1_30.txt, 1_31.txt, 1_32.txt, 1_33.txt, 1_34.txt, 1_35.txt, 1_36.txt, 1_37.txt, 1_38.txt, 1_39.txt, 1_40.txt, 1_41.txt, 1_42.txt, 1_43.txt, 1_44.txt, 1_45.txt, 1_46.txt, 1_47.txt, 1_48.txt, 1_49.txt, 1_50.txt, 1_51.txt, 1_52.txt, 1_53.txt, 1_54.txt, 1_55.txt, 1_56.txt, 1_57.txt, 1_58.txt, 1_59.txt, 1_60.txt, 1_61.txt, 1_62.txt, 1_63.txt, 1_64.txt, 1_65.txt, 1_66.txt, 1_67.txt, 1_68.txt, 1_69.txt
Case Name Status Exec Time Memory
0_00.txt AC 2 ms 2304 KB
0_01.txt AC 2 ms 2304 KB
0_02.txt AC 2 ms 2304 KB
0_03.txt AC 1 ms 2304 KB
1_00.txt AC 2 ms 2304 KB
1_01.txt AC 2 ms 2304 KB
1_02.txt AC 2 ms 2304 KB
1_03.txt AC 1 ms 2304 KB
1_04.txt AC 1 ms 2304 KB
1_05.txt AC 2 ms 2304 KB
1_06.txt AC 2 ms 2304 KB
1_07.txt AC 54 ms 7936 KB
1_08.txt AC 69 ms 8832 KB
1_09.txt AC 74 ms 8576 KB
1_10.txt AC 12 ms 2944 KB
1_11.txt AC 13 ms 2944 KB
1_12.txt AC 13 ms 2944 KB
1_13.txt AC 13 ms 2944 KB
1_14.txt AC 21 ms 2944 KB
1_15.txt AC 20 ms 2944 KB
1_16.txt AC 21 ms 2944 KB
1_17.txt AC 21 ms 2944 KB
1_18.txt AC 26 ms 2944 KB
1_19.txt AC 26 ms 2944 KB
1_20.txt AC 26 ms 2944 KB
1_21.txt AC 26 ms 2944 KB
1_22.txt AC 33 ms 2944 KB
1_23.txt AC 31 ms 2944 KB
1_24.txt AC 31 ms 2944 KB
1_25.txt AC 32 ms 2944 KB
1_26.txt AC 37 ms 2944 KB
1_27.txt AC 37 ms 2944 KB
1_28.txt AC 37 ms 2944 KB
1_29.txt AC 38 ms 2944 KB
1_30.txt AC 46 ms 3072 KB
1_31.txt AC 46 ms 3072 KB
1_32.txt AC 47 ms 3072 KB
1_33.txt AC 48 ms 3072 KB
1_34.txt AC 64 ms 3328 KB
1_35.txt AC 65 ms 3328 KB
1_36.txt AC 64 ms 3328 KB
1_37.txt AC 65 ms 3328 KB
1_38.txt AC 96 ms 4736 KB
1_39.txt AC 95 ms 4736 KB
1_40.txt AC 94 ms 4736 KB
1_41.txt AC 95 ms 4736 KB
1_42.txt AC 126 ms 6912 KB
1_43.txt AC 123 ms 7040 KB
1_44.txt AC 123 ms 7040 KB
1_45.txt AC 122 ms 7040 KB
1_46.txt AC 132 ms 8192 KB
1_47.txt AC 131 ms 8192 KB
1_48.txt AC 132 ms 8192 KB
1_49.txt AC 131 ms 8192 KB
1_50.txt AC 133 ms 8576 KB
1_51.txt AC 131 ms 8448 KB
1_52.txt AC 134 ms 8576 KB
1_53.txt AC 132 ms 8576 KB
1_54.txt AC 133 ms 8704 KB
1_55.txt AC 129 ms 8576 KB
1_56.txt AC 134 ms 8832 KB
1_57.txt AC 133 ms 8704 KB
1_58.txt AC 134 ms 8704 KB
1_59.txt AC 134 ms 8704 KB
1_60.txt AC 133 ms 8704 KB
1_61.txt AC 133 ms 8704 KB
1_62.txt AC 134 ms 8832 KB
1_63.txt AC 126 ms 8448 KB
1_64.txt AC 132 ms 8704 KB
1_65.txt AC 132 ms 8704 KB
1_66.txt AC 132 ms 8704 KB
1_67.txt AC 131 ms 8704 KB
1_68.txt AC 134 ms 8704 KB
1_69.txt AC 133 ms 8704 KB