35. Search Insert Position
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.
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
Solution
class Solution {
public int searchInsert(int[] nums, int target) {
int len = nums.length;
int start = 0;
int end = len - 1;
//Shall check start == end case, since the start/end might be unchecked
//for ex: 2,4,5 target = 3, start = 0, end = 0(ie.mid-1),
//however the insert index shall be 1
//for ex: 2,4,7 target = 8, start = 2(ie.mid+1), end = 2,
//however the insert index shall be 3
while(start <= end){
//For avoid start+end is overflowed
int mid = start + (end - start)/2;
if(nums[mid] == target)
return mid;
else if (nums[mid] < target){
start = mid + 1;
}
else{
//mid > target
end = mid - 1;
}
}
return start;
}
}
Last updated
Was this helpful?