LeetCode刷题日志-153.寻找旋转排序数组中的最小值

思路:总所周知二分的逻辑非常简单,难点在边界处理。这道题我说说自己的理解, 首先二分的根本是有序,只要有序就能二分,哪怕是部分有序(这个是重点!!) 我们先搞清楚题目中的数组是通过怎样的变化得来的,基本上就是等于将整个数组向右平移(想象一个圆形的环)。重点来了,不管怎么移,数组总有一半是有序的!!要么左半边完全有序,要么右半边完全有序。 那么大家可以想想,最小值在有序的那半边还是无序的那半边。答案很显然是在无序的那半边(想想数组是如何变化得来的)。那就很简单了,每一次二分都找无序的那一半,到最后剩下的就是最小值。

java 复制代码
class Solution {
    public int findMin(int[] nums) {
        if(nums[0] <= nums[nums.length - 1])
            return nums[0];

        int left = 0;
        int right = nums.length - 1;
        int mid = -1;

        while(left < right) {
            mid = (left + right) / 2;
            if(nums[mid] > nums[right]) //判断哪边是有序的
                left = mid + 1;  //将范围缩小到无序的那一半,因为答案就在那一半。之所以要+1,是因为mid肯定不是最小的那个,至少nums[right]比nums[mid]更小
            else
                right = mid; //这里直接取mid,因为此时mid的左边(包含)是不完全有序的那一半,mid有可能直接是最小值,所以要取mid
        }
        return nums[left];
    }
}
相关推荐
DuHz7 小时前
论文精读:大语言模型 (Large Language Models, LLM) —— 一项调查
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·语言模型
加农炮手Jinx7 小时前
LeetCode 72. Edit Distance 题解
算法·leetcode·力扣
借雨醉东风7 小时前
程序分享--常见算法/编程面试题:旋转矩阵
c++·线性代数·算法·面试·职场和发展·矩阵
_深海凉_7 小时前
LeetCode热题100-打家劫舍
算法·leetcode·职场和发展
jghhh018 小时前
使用 MATLAB 实现支持向量回归 (SVR) 预测未来数据
算法·matlab
云泽8088 小时前
笔试算法 - 双指针篇(二):四大经典求和题型 + 有效三角形计数问题
c++·算法
刀法如飞9 小时前
【合并已排序数组的三种实现策略,哪一种更可取?】
算法·程序员
王老师青少年编程10 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【区间贪心】:种树
c++·算法·贪心·csp·信奥赛·区间贪心·种树
hi_ro_a10 小时前
C++ 哈希表封装 unordered_map /unordered_set
数据结构·c++·算法·哈希算法
Jasmine_llq14 小时前
《B4447 [GESP202512 二级] 环保能量球》
数据结构·算法·数学公式计算(核心)·整数除法算法·多组数据循环处理·输入输出算法·简单模拟算法