Submission #2182992
Source Code Expand
import java.util.ArrayDeque; import java.util.ArrayList; import java.util.Deque; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Scanner; import java.util.Set; class Main{ 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]; int index=0; for(int i=0;i<N;++i)if(a[i]==b[i])used[i]=true; while(true){ int nextIndex=-1; if(bNumToIndex.containsKey(x)){ nextIndex=bNumToIndex.get(x).poll(); while(used[nextIndex] && !bNumToIndex.get(x).isEmpty()){ nextIndex = bNumToIndex.get(x).poll(); } if(bNumToIndex.get(x).isEmpty())bNumToIndex.remove(x); if(used[nextIndex])nextIndex=-1; } if(nextIndex<0){ while(index<N &&used[index])++index; if(index>=N)break; nextIndex=index; ++ans; } used[nextIndex]=true; if(x!=a[nextIndex]){ ++ans; x=a[nextIndex]; }; } System.out.println(ans); } }
Submission Info
Submission Time | |
---|---|
Task | D - XOR Replace |
User | inmir |
Language | Java8 (OpenJDK 1.8.0) |
Score | 0 |
Code Size | 2291 Byte |
Status | WA |
Exec Time | 840 ms |
Memory | 106596 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 | 93 ms | 17620 KB |
0_01.txt | AC | 92 ms | 19412 KB |
0_02.txt | AC | 90 ms | 21716 KB |
0_03.txt | AC | 92 ms | 19924 KB |
1_00.txt | AC | 92 ms | 21716 KB |
1_01.txt | AC | 93 ms | 21844 KB |
1_02.txt | AC | 93 ms | 20820 KB |
1_03.txt | AC | 92 ms | 19796 KB |
1_04.txt | AC | 91 ms | 19924 KB |
1_05.txt | AC | 93 ms | 19796 KB |
1_06.txt | AC | 94 ms | 23124 KB |
1_07.txt | AC | 665 ms | 106596 KB |
1_08.txt | AC | 731 ms | 105044 KB |
1_09.txt | AC | 706 ms | 104868 KB |
1_10.txt | AC | 635 ms | 72516 KB |
1_11.txt | AC | 620 ms | 61636 KB |
1_12.txt | AC | 707 ms | 71128 KB |
1_13.txt | AC | 647 ms | 69448 KB |
1_14.txt | WA | 670 ms | 85656 KB |
1_15.txt | AC | 664 ms | 72696 KB |
1_16.txt | WA | 709 ms | 85908 KB |
1_17.txt | AC | 670 ms | 93184 KB |
1_18.txt | WA | 666 ms | 88328 KB |
1_19.txt | AC | 840 ms | 73104 KB |
1_20.txt | WA | 701 ms | 91192 KB |
1_21.txt | AC | 647 ms | 77780 KB |
1_22.txt | WA | 677 ms | 83824 KB |
1_23.txt | AC | 637 ms | 68800 KB |
1_24.txt | WA | 710 ms | 93024 KB |
1_25.txt | AC | 646 ms | 77004 KB |
1_26.txt | WA | 718 ms | 83764 KB |
1_27.txt | AC | 633 ms | 73068 KB |
1_28.txt | WA | 693 ms | 90464 KB |
1_29.txt | AC | 642 ms | 75452 KB |
1_30.txt | WA | 702 ms | 84952 KB |
1_31.txt | AC | 662 ms | 67024 KB |
1_32.txt | WA | 710 ms | 87448 KB |
1_33.txt | AC | 654 ms | 92152 KB |
1_34.txt | WA | 707 ms | 85304 KB |
1_35.txt | AC | 648 ms | 73344 KB |
1_36.txt | WA | 743 ms | 83348 KB |
1_37.txt | AC | 648 ms | 70232 KB |
1_38.txt | WA | 764 ms | 95732 KB |
1_39.txt | AC | 634 ms | 72504 KB |
1_40.txt | WA | 754 ms | 95828 KB |
1_41.txt | AC | 643 ms | 72592 KB |
1_42.txt | WA | 809 ms | 102696 KB |
1_43.txt | AC | 653 ms | 66056 KB |
1_44.txt | WA | 785 ms | 100892 KB |
1_45.txt | AC | 646 ms | 71760 KB |
1_46.txt | WA | 785 ms | 99744 KB |
1_47.txt | AC | 632 ms | 74084 KB |
1_48.txt | WA | 779 ms | 95832 KB |
1_49.txt | AC | 645 ms | 94344 KB |
1_50.txt | WA | 799 ms | 100072 KB |
1_51.txt | AC | 619 ms | 64836 KB |
1_52.txt | WA | 808 ms | 104212 KB |
1_53.txt | AC | 634 ms | 70312 KB |
1_54.txt | WA | 806 ms | 96800 KB |
1_55.txt | AC | 682 ms | 72968 KB |
1_56.txt | WA | 800 ms | 96780 KB |
1_57.txt | AC | 646 ms | 77016 KB |
1_58.txt | WA | 799 ms | 98096 KB |
1_59.txt | AC | 693 ms | 92136 KB |
1_60.txt | WA | 763 ms | 97652 KB |
1_61.txt | AC | 641 ms | 74536 KB |
1_62.txt | WA | 793 ms | 100008 KB |
1_63.txt | AC | 649 ms | 75044 KB |
1_64.txt | WA | 786 ms | 104848 KB |
1_65.txt | AC | 637 ms | 70580 KB |
1_66.txt | WA | 769 ms | 104324 KB |
1_67.txt | AC | 618 ms | 71620 KB |
1_68.txt | WA | 789 ms | 93484 KB |
1_69.txt | AC | 638 ms | 75228 KB |