$ cat ./coding/154-find-minimum-in-rotated-sorted-array-ii.md
[Coding]
154. Find Minimum in Rotated Sorted Array II
────────────────────────────────────────────────────────────
154. Find Minimum in Rotated Sorted Array II
- 如果中間的值比最右邊的大,那代表最小值在右區間
- 如果中間的值比最右邊的小,那代表最小值在左區間
但是因為有重複的值,所以遇到重複的時候,右邊邊界縮小一,為什麼不能左邊界加一?因為我們是要找最小值,如果左邊界加一可能會把最小值給跳過了。
class Solution:
def findMin(self, nums: List[int]) -> int:
left = 0
right = len(nums) - 1
while left < right:
mid = left + (right - left) // 2
if nums[mid] > nums[right]:
left = mid + 1
elif nums[mid] < nums[right]:
right = mid
else:
right -= 1
return nums[left]
--tags#Binary Search
$ ls ./coding/ | grep -v 154-find-minimum-in-rotated-sorted-array-ii