LeetCode刷题实战154:寻找旋转排序数组中的最小值 II
Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.
(i.e., [0,1,2,4,5,6,7] might become [4,5,6,7,0,1,2]).
Find the minimum element.
The array may contain duplicates.
题意
示例 1:
输入: [1,3,5]
输出: 1
示例 2:
输入: [2,2,2,0,1]
输出: 0
解题
class Solution(object):
def findMin(self, numbers):
"""
:type numbers: List[int]
:rtype: int
"""
left = 0
right = len(numbers) - 1
while left < right:
mid = left + (right - left) // 2
if numbers[right] > numbers[mid]:
right = mid
else :
if numbers[right] < numbers[mid]:
left = mid + 1
else:
right -= 1
return numbers[left]
