Submission #2183237
Source Code Expand
import java.util.ArrayDeque; import java.util.ArrayList; import java.util.HashSet; import java.util.Deque; import java.util.HashMap; import java.util.Set; import java.util.List; import java.util.Map; import java.util.Scanner; import java.util.Set; class Main{ static int pare[]; static int root(int v){ if(pare[v]<0)return v; return pare[v]=root(pare[v]); } static int size(int v){ return -pare[root(v)]; } static void union(int v,int u){ v =root(v); u =root(u); if(v==u)return; if(size(u)>size(v)){ int tmp=u; u=v; v=tmp; } pare[v]+=pare[u]; pare[u]=v; } public static void main(String[] args){ Scanner scan = new Scanner(System.in); int N = scan.nextInt(); long[] a = new long[N]; long[] b = new long[N]; for(int i=0;i<N;++i)a[i] =scan.nextLong(); for(int i=0;i<N;++i)b[i] =scan.nextLong(); Map<Long,Integer> countmap = new HashMap<>(); long x = 0; for(int i=0;i<N;++i)x^=a[i]; countmap.put(x,1); for(int i=0;i<N;++i){ if(!countmap.containsKey(a[i]))countmap.put(a[i],0); countmap.put(a[i], countmap.get(a[i])+1); } for(int i=0;i<N;++i){ if(!countmap.containsKey(b[i]) || countmap.get(b[i])==0){ System.out.println(-1); return; } countmap.put(b[i], countmap.get(b[i])-1); } Map<Long, Deque<Integer>> bNumToIndex = new HashMap<>(); for(int i=0;i<N;++i){ if(!bNumToIndex.containsKey(b[i]))bNumToIndex.put(b[i],new ArrayDeque<>()); bNumToIndex.get(b[i]).add(i); } int ans =0; boolean used[] = new boolean[N]; for(int i=0;i<N;++i)if(a[i]==b[i])used[i]=true; boolean remX=true; for(int i=0;i<N;++i)if(!used[i] && b[i]==x)remX=false; if(!remX)ans--; pare = new int[2*N]; for(int i=0;i<2*N;++i)pare[i]=-1; for(int i=0;i<N;++i)if(!used[i] && b[i]!=x)union(i,N+i); for(int i=0;i<N;++i){ while(bNumToIndex.containsKey(a[i])&& !bNumToIndex.get(a[i]).isEmpty()){ union(i,N+bNumToIndex.get(a[i]).poll()); } } Set<Integer> set = new HashSet<>(); for(int i=0;i<N;++i){ if(!used[i])set.add(root(i)); else --ans; } ans += N +set.size(); System.out.println(ans); } }
Submission Info
Submission Time | |
---|---|
Task | D - XOR Replace |
User | inmir |
Language | Java8 (OpenJDK 1.8.0) |
Score | 0 |
Code Size | 2638 Byte |
Status | WA |
Exec Time | 920 ms |
Memory | 106100 KB |
Judge Result
Set Name | Sample | All | ||||||
---|---|---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 0 / 1000 | ||||||
Status |
|
|
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 | 182 ms | 20436 KB |
0_01.txt | AC | 94 ms | 19668 KB |
0_02.txt | AC | 92 ms | 21844 KB |
0_03.txt | AC | 94 ms | 19668 KB |
1_00.txt | AC | 91 ms | 21844 KB |
1_01.txt | AC | 91 ms | 19924 KB |
1_02.txt | AC | 93 ms | 21716 KB |
1_03.txt | AC | 94 ms | 21584 KB |
1_04.txt | AC | 94 ms | 20692 KB |
1_05.txt | AC | 93 ms | 18644 KB |
1_06.txt | AC | 93 ms | 18644 KB |
1_07.txt | AC | 729 ms | 103844 KB |
1_08.txt | AC | 741 ms | 103820 KB |
1_09.txt | AC | 727 ms | 104604 KB |
1_10.txt | WA | 688 ms | 75880 KB |
1_11.txt | AC | 589 ms | 64732 KB |
1_12.txt | WA | 681 ms | 68752 KB |
1_13.txt | WA | 691 ms | 78916 KB |
1_14.txt | WA | 772 ms | 90364 KB |
1_15.txt | AC | 580 ms | 70080 KB |
1_16.txt | WA | 679 ms | 86716 KB |
1_17.txt | AC | 641 ms | 90408 KB |
1_18.txt | WA | 735 ms | 91596 KB |
1_19.txt | AC | 655 ms | 75168 KB |
1_20.txt | WA | 727 ms | 91160 KB |
1_21.txt | AC | 642 ms | 75512 KB |
1_22.txt | WA | 751 ms | 91004 KB |
1_23.txt | AC | 640 ms | 72984 KB |
1_24.txt | WA | 755 ms | 89280 KB |
1_25.txt | AC | 642 ms | 76524 KB |
1_26.txt | WA | 767 ms | 91424 KB |
1_27.txt | AC | 643 ms | 73532 KB |
1_28.txt | WA | 757 ms | 92024 KB |
1_29.txt | AC | 642 ms | 75028 KB |
1_30.txt | WA | 758 ms | 92220 KB |
1_31.txt | AC | 669 ms | 70792 KB |
1_32.txt | WA | 844 ms | 91332 KB |
1_33.txt | AC | 675 ms | 92112 KB |
1_34.txt | WA | 802 ms | 94732 KB |
1_35.txt | AC | 640 ms | 71760 KB |
1_36.txt | WA | 835 ms | 94576 KB |
1_37.txt | AC | 661 ms | 87956 KB |
1_38.txt | WA | 793 ms | 98628 KB |
1_39.txt | AC | 612 ms | 64532 KB |
1_40.txt | WA | 881 ms | 92276 KB |
1_41.txt | AC | 662 ms | 73332 KB |
1_42.txt | WA | 861 ms | 106100 KB |
1_43.txt | AC | 658 ms | 74064 KB |
1_44.txt | WA | 833 ms | 92268 KB |
1_45.txt | AC | 661 ms | 75252 KB |
1_46.txt | WA | 906 ms | 98372 KB |
1_47.txt | AC | 662 ms | 77516 KB |
1_48.txt | WA | 820 ms | 91468 KB |
1_49.txt | AC | 637 ms | 70932 KB |
1_50.txt | WA | 815 ms | 101768 KB |
1_51.txt | AC | 695 ms | 70852 KB |
1_52.txt | WA | 860 ms | 91624 KB |
1_53.txt | AC | 615 ms | 63552 KB |
1_54.txt | WA | 920 ms | 97928 KB |
1_55.txt | AC | 652 ms | 75552 KB |
1_56.txt | WA | 917 ms | 97776 KB |
1_57.txt | AC | 647 ms | 77484 KB |
1_58.txt | WA | 808 ms | 92588 KB |
1_59.txt | AC | 691 ms | 91992 KB |
1_60.txt | AC | 867 ms | 95552 KB |
1_61.txt | AC | 639 ms | 74488 KB |
1_62.txt | WA | 887 ms | 100136 KB |
1_63.txt | AC | 654 ms | 71876 KB |
1_64.txt | WA | 865 ms | 95936 KB |
1_65.txt | AC | 638 ms | 66092 KB |
1_66.txt | WA | 811 ms | 100648 KB |
1_67.txt | AC | 650 ms | 73072 KB |
1_68.txt | AC | 878 ms | 96880 KB |
1_69.txt | AC | 638 ms | 71236 KB |