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

已知一个长度为 n 的数组,预先按照升序排列,经由 1n旋转 后,得到输入数组。例如,原数组 nums = [0,1,2,4,5,6,7] 在变化后可能得到:

  • 若旋转 4 次,则可以得到 [4,5,6,7,0,1,2]
  • 若旋转 7 次,则可以得到 [0,1,2,4,5,6,7]

注意,数组 [a[0], a[1], a[2], ..., a[n-1]] 旋转一次 的结果为数组 [a[n-1], a[0], a[1], a[2], ..., a[n-2]]

给你一个元素值 互不相同 的数组 nums ,它原来是一个升序排列的数组,并按上述情形进行了多次旋转。请你找出并返回数组中的 最小元素

你必须设计一个时间复杂度为 O(log n) 的算法解决此问题。

示例 1:

复制代码
输入:nums = [3,4,5,1,2]
输出:1
解释:原数组为 [1,2,3,4,5] ,旋转 3 次得到输入数组。

示例 2:

复制代码
输入:nums = [4,5,6,7,0,1,2]
输出:0
解释:原数组为 [0,1,2,4,5,6,7] ,旋转 3 次得到输入数组。

示例 3:

复制代码
输入:nums = [11,13,15,17]
输出:11
解释:原数组为 [11,13,15,17] ,旋转 4 次得到输入数组。

编程思路

旋转会使数组变得无序,而最小值就在无序的区间中。而在有序的数组中,最左边就是最小值。

所有有把区间向无序区间收缩,直到缩小到区间变得有序,这时最左边就是最小值

python 复制代码
class Solution:
    def findMin(self, nums: List[int]) -> int:
        left = 0
        right = len(nums) - 1

        while left < right:
            mid = (left + right) // 2
            if nums[mid] >= nums[right]: #判断右边是否无序
                left = mid + 1 #如果无序,说明最小值在右边,把区间缩小到右边
            else:
                right = mid #否则缩小到左边
        
        return nums[left]
相关推荐
hope_wisdom10 分钟前
C/C++数据结构之用链表实现栈
c语言·数据结构·c++·链表·
DuHz16 分钟前
使用稀疏采样方法减轻汽车雷达干扰——论文阅读
论文阅读·算法·汽车·信息与通信·信号处理
大肘子咒你35 分钟前
数字狂潮来袭
数据结构·c++·1024程序员节
hansang_IR37 分钟前
【算法速成课 3】康托展开(Cantor Expansion)/ 题解 P3014 [USACO11FEB] Cow Line S
c++·算法·状态压缩·康托展开·排列映射
m0_7482336444 分钟前
【类与对象(中)】C++类默认成员函数全解析
开发语言·c++·算法
scilwb1 小时前
STM32 实战:驯服失控的 M3508 电机 - PID 位置环频率的“坑”与“药”
算法·代码规范
chonbw1 小时前
226.翻转二叉树
算法·leetcode
岑梓铭2 小时前
《考研408数据结构》第六章(5.1+5.2+5.3树、二叉树、线索二叉树)复习笔记
数据结构·笔记·考研·408·1024程序员节
苏纪云2 小时前
数据结构<C++>——数组
java·数据结构·c++·数组·动态数组
周杰伦_Jay2 小时前
【 RocketMQ 全解析】分布式消息队列的架构、消息转发与快速实践、事务消息
分布式·算法·架构·rocketmq·1024程序员节