Find missing number

In an Unsorted Array size N - 1 of 1 to N, find the missing number in O(n) time

Solution 1: HashMap

Average case: O(N)

Worst Case: O(N^2)

Solution 2: Boolean Array

input: 7 2 4 1 5 3

boolArr: 1? 2? 3? 4? 5? 6? 7?

Total num = input.length + 1 = 7

Boolean[] boolArr = new Boolean[input + 1];
Arrays.fill(array, Boolean.FALSE);

for (int cur: input){
    boolArr[cur - 1] = true; //int 7 -> boolArr[6] = true
}
for (int i = 0; i < boolArr.length; i++){
    if (boolArr[i] == false) System.out.println(i + 1);
}

Time Comp: O(traverse input + traverse boolArr) = O(2N) = (N)

Solution 3: Subtract

int sum = 0;
for (int i = 1; i <= input.length + 1; i++){
    sum += i;
}

int cursum = 0;
for (int i: input){
    cursum += i
}

return sum - cursum;

Time Comp: O(traverse input + add 1->N) = O(N + N) = O(2N) = O(N)

Solution 4: XOR

  public int missing(int[] array) {

    if (array.length == 0) return 1; 

    //XOR method 
    int x1 = array[0];
    int x2 = 1;
    int n = array.length;

    //XOR input array 1 -> n
    for ( int i = 1; i < n; i++){
      x1 = x1 ^ array[i];
    }

    //XOR ideal array 1 -> n + 1
    for (int i = 2; i <= n + 1; i++){
      x2 = x2 ^ i;
    }

    return (x1 ^ x2);
  }

Time Comp: O(One traversal + N XOR in x2) = O(2N) = O(N)

Space Comp: O(1)

Last updated

Was this helpful?