Table of contents


Given problem

Given a sorted array and a target value, return the index if the target is found. If not, return the index where it would be if it were inserted in order.

You may assume no duplicates in the array.

Below is an test case for this problem.

Example 1:

Input: [1,3,5,6], 5
Output: 2
Example 2:

Input: [1,3,5,6], 2
Output: 1
Example 3:

Input: [1,3,5,6], 7
Output: 4
Example 4:

Input: [1,3,5,6], 0
Output: 0


Using Binary Search algorithm

Our array is sorted, so we can apply Binary Search algorithm to deal with it.

Below is the source code that using Binary Search algorithm.

  1. Using first invariant

     public int searchInsert(int[] nums, int target) {
         int left = 0;
         int right = nums.length - 1;
    
         while (left <= right) {
             int mid = left + (right - left) / 2;
    
             if (nums[mid] == target) {
                 return mid;
             } else if (nums[mid] < target) {
                 left = mid + 1;
             } else {
                 right = mid - 1;
             }
         }
    
         return left;
     }
    
  2. Using third invariant

     public static int searchInsert(int[] nums, int target) {
         int blue = -1;
         int red = nums.length;
    
         while (blue + 1 != red) {
             int mid = blue + (red - blue) / 2;
    
             if (nums[mid] == target) {
                 return mid;
             }
    
             if (nums[mid] < target) {
                 blue = mid;
             } else {
                 red = mid;
             }
         }
    
         return red;
     }
    

The complexity of this way:

  • Time complexity: O(log(n))
  • Space complexity: O(1)


Wrapping up

  • Apply Binary Search algorithm when we have sorted array.


References:

35. Search Insert Position