LeetCode 153. Find Minimum in Rotated Sorted Array

简介: 假设按照升序排序的数组在预先未知的某个点上进行了旋转。( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。请找出其中最小的元素。你可以假设数组中不存在重复元素。

v2-752ca4f726a5b6b60508b5c4f8156cfb_1440w.jpg

Description



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.

You may assume no duplicate exists in the array.


Example 1:

Input: [3,4,5,1,2]

Output: 1


Example 2:

Input: [4,5,6,7,0,1,2]

Output: 0


描述



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

( 例如,数组 [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


思路



  • 此题目考察二分法.
  • 二分法的关键是判断需搜索的值是在当前位置的左边还是当前位置的右边.
  • 此题目中,在没有重复的情况下,一个递增的序列从某个位置p旋转,最小值会小于新数组的左右两端的数值,会使得从数组不在连续递增.反过来说,如果某一段数组连续递增,那么转换的枢纽一定不在此段中.
  • 因此,我们计算中间值,如果数组nums[middle]>nums[0],说明从0到middle(包括)一直在递增,那么要求的枢纽一定在middle(不包括middle本身)右边.
  • 同理如果,nums[middle]<\nums[-1](-1表示最后一个元素),说明从middle到最后一个元素一直在递增,那么要求的枢纽一定在middle左边(包括middle本身,因为middle可能是枢纽本身).
  • 最后找到了middle会满足nums[middle] < nums[middle + 1] < nums[middle - 1]


# -*- coding: utf-8 -*-
# @Author:             何睿
# @Create Date:        2019-01-15 13:52:03
# @Last Modified by:   何睿
# @Last Modified time: 2019-01-15 16:00:40
class Solution:
    def findMin(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        # 如果为空,则直接返回
        if not nums:
            return 0
        # left为最左边的索引,right为最右边的索引
        left, right = 0, len(nums) - 1
        # 首先获取中间值
        middle = left + ((right - left) >> 1)
        # 如果是连续递增的请情况,返回数组的第一个值
        if nums[0] <= nums[middle] <= nums[-1]:
            return nums[0]
        # 如果是连续递减的情况,返回最后一个值
        if nums[-1] <= nums[middle] <= nums[0]:
            return nums[-1]
        while left < right:
            middle = left + ((right - left) >> 1)
            # 结束条件,交换的位置满足下面的条件
            if nums[middle] < nums[middle + 1] < nums[middle - 1]:
                return nums[middle]
            if nums[middle] > nums[0]:
                left = middle + 1
            # 注意这里不是middle-1,因为有可能middle就是要求的枢纽位置
            if nums[middle] < nums[-1]:
                right = middle
        return nums[left]


源代码文件在这里.


目录
相关文章
|
8月前
|
Java
Leetcode 295. Find Median from Data Stream
在一个有序数组中找中位数,但需要支持再数组中添加新的元素。本来是有序里的,可以很轻易就查到中位数,但如果添加新数字后,不一定有序。如果先对数组排序,那代价就比较大了,每次排序时间复杂度O(n*log(n)),看discuss发现了一种很巧妙的解法,可以把添加数据的时间复杂度降低到O(log(n)) ,查询中位数O(1)。
30 0
|
8月前
Leetcode 4. Median of Two Sorted Arrays
题目描述很简单,就是找到两个有序数组合并后的中位数,要求时间复杂度O(log (m+n))。 如果不要去时间复杂度,很容易就想到了归并排序,归并排序的时间复杂度是O(m+n),空间复杂度也是O(m+n),不满足题目要求,其实我开始也不知道怎么做,后来看了别人的博客才知道有个二分法求两个有序数组中第k大数的方法。
19 0
|
8月前
Leetcode Find Minimum in Rotated Sorted Array 题解
对一个有序数组翻转, 就是随机取前K个数,移动到数组的后面,然后让你找出最小的那个数,注意,K有可能是0,也就是没有翻转。
28 0
|
11月前
|
JavaScript 前端开发 索引
Array类型【find】
Array类型【find】
69 0
Search in Rotated Sorted Array - 循环有序数组查找问题
Search in Rotated Sorted Array - 循环有序数组查找问题
55 0
LeetCode 167 Two Sum II - Input array is sorted(输入已排序数组,求其中两个数的和等于给定的数)
给定一个有序数组和一个目标值 找出数组中两个成员,两者之和为目标值,并顺序输出
66 0
LeetCode contest 200 5476. 找出数组游戏的赢家 Find the Winner of an Array Game
LeetCode contest 200 5476. 找出数组游戏的赢家 Find the Winner of an Array Game
|
2月前
|
Python
使用array()函数创建数组
使用array()函数创建数组。
29 3
|
2月前
|
存储 安全 Swift
在Swift中,数组(Array)
在Swift中,数组(Array)
38 3
|
2月前
|
JavaScript 前端开发
总结TypeScript 的一些知识点:TypeScript Array(数组)(下)
一个数组的元素可以是另外一个数组,这样就构成了多维数组(Multi-dimensional Array)。