-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path0035_search_insert_position.py
More file actions
73 lines (59 loc) · 1.86 KB
/
0035_search_insert_position.py
File metadata and controls
73 lines (59 loc) · 1.86 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
"""
35. Search Insert Position
Given a sorted array of distinct integers 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 must write an algorithm with O(log n) runtime complexity.
Example 1:
Input: nums = [1,3,5,6], target = 5
Output: 2
Example 2:
Input: nums = [1,3,5,6], target = 2
Output: 1
Example 3:
Input: nums = [1,3,5,6], target = 7
Output: 4
Constraints:
=================
1 <= nums.length <= 10**4
-10**4 <= nums[i] <= 10**4
nums contains distinct values sorted in ascending order.
-10**4 <= target <= 10**4
"""
from typing import List
class Solution:
def searchInsert(self, nums: List[int], target: int) -> int:
left = 0
right = len(nums) - 1
pos = int((left + right) / 2)
while left != right:
if target == nums[pos]:
return pos
elif target < nums[pos]:
if right-left > 1:
right = pos
else:
# avoid infinity cycling
right -= 1
elif target > nums[pos]:
if right-left > 1:
left = pos
else:
# avoid infinity cycling
left += 1
pos = int((left + right) / 2)
if target <= nums[pos]:
return pos
else:
return pos + 1
sol = Solution()
assert sol.searchInsert([1, 3, 5, 6], 5) == 2
assert sol.searchInsert([1, 3, 5, 6], 2) == 1
assert sol.searchInsert([1, 3, 5, 6], 7) == 4
assert sol.searchInsert([1, 3, 5, 6], 0) == 0
assert sol.searchInsert([1, 3, 5, 6], -1) == 0
assert sol.searchInsert([1, 3, 5, 6], 11) == 4
assert sol.searchInsert([1, 3, 5, 6], -11) == 0
assert sol.searchInsert([0], -1) == 0
assert sol.searchInsert([0], 1) == 1
assert sol.searchInsert([0], 0) == 0