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.
Input: [1,3,5,6], 5 Output: 2
Input: [1,3,5,6], 2 Output: 1
Input: [1,3,5,6], 7 Output: 4
Input: [1,3,5,6], 0 Output: 0
class Solution:
def searchInsert(self, nums: List[int], target: int) -> int:
if not nums or target <= nums[0]:
return 0
if target > nums[-1]:
return len(nums)
for i in range(1, len(nums)):
if target == nums[i] or (target > nums[i - 1] and target < nums[i]):
return i
class Solution:
def searchInsert(self, nums: List[int], target: int) -> int:
if not nums or target <= nums[0]:
return 0
if target > nums[-1]:
return len(nums)
left = 1
right = len(nums) - 1
while left <= right:
mid = (left + right) // 2
if target == nums[mid]:
return mid
elif target > nums[mid]:
left = mid + 1
if target < nums[left]:
return left
elif target < nums[mid]:
right = mid - 1
if target > nums[right]:
return mid