LeetCode153.寻找旋转排序数组中的最小值

时间:2023-03-10 06:38:00
LeetCode153.寻找旋转排序数组中的最小值

153.寻找旋转排序数组中的最小值

描述

假设按照升序排序的数组在预先未知的某个点上进行了旋转。

( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。

请找出其中最小的元素。

你可以假设数组中不存在重复元素。

示例

示例 1:

输入: [3,4,5,1,2]
输出: 1

例 2:

输入: [4,5,6,7,0,1,2]
输出: 0

思路

这题要求在一个轮转了的排序数组里面找到最小值, 我们可以用二分法来做。

首先我们需要知道, 对于一个区间 A, 如果 A[start] < A[stop], 那么该区间一定是有序的了。

假设在一个轮转的排序数组 A, 我们首先获取中间元素的值, A[mid], mid = (start + stop) / 2。 因为数组没有重复元素, 那么就有两种情况:

  • A[mid] > A[start], 那么最小值一定在右半区间, 譬如 [4,5,6,7,0,1,2], 中间元素为 7, 7 > 4, 最小元素一定在 [7,0,1,2] 这边, 于是我们继续在这个区间查找。
  • A[mid] < A[start], 那么最小值一定在左半区间, 譬如 [7,0,1,2,4,5,6], 这件元素为 2, 2 < 7, 我们继续

    在 [7,0,1,2] 这个区间查找。
class Solution:
def findMin(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
len_nums = len(nums) if len_nums == 0:
return 0
elif len_nums == 1:
return nums[0]
elif len_nums == 2:
return min(nums[0], nums[1]) start = 0
stop = len_nums - 1 while start < stop - 1:
if nums[start] < nums[stop]:
return nums[start] mid = start + (stop - start) // 2 if nums[mid] > nums[start]:
start = mid
elif nums[mid] < nums[start]:
stop = mid return min(nums[start], nums[stop])

GitHub地址:https://github.com/protea-ban/LeetCode

LeetCode153.寻找旋转排序数组中的最小值