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];
    }
}
相关推荐
Lsk_Smion23 分钟前
Hot100(开刷) 之 长度最小的数组--删除倒数第N个链表--层序遍历
java·数据结构·算法·kotlin
luoganttcc24 分钟前
dim3 grid_size(2, 3, 4); dim3 block_size(4, 8, 4)算例
算法
WBluuue33 分钟前
Codeforces 1088 Div1+2(ABC1C2DEF)
c++·算法
蓝色的杯子41 分钟前
Python面试30分钟突击掌握-LeetCode3-Linked list
python·leetcode·面试
像素猎人42 分钟前
map<数据类型,数据类型> mp和unordered_map<数据类型,数据类型> ump的讲解,蓝桥杯OJ4567最大数目
c++·算法·蓝桥杯·stl·map
Narrastory43 分钟前
Note:强化学习(一)
人工智能·算法·强化学习
沐雪轻挽萤1 小时前
1. C++17新特性-序章
java·c++·算法
郝学胜-神的一滴1 小时前
从链表到二叉树:树形结构的入门与核心性质解析
数据结构·c++·python·算法·链表
csdn_aspnet1 小时前
C语言 (QuickSort using Random Pivoting)使用随机枢轴的快速排序
c语言·算法·排序算法
玖釉-1 小时前
深入解析 meshoptimizer:基于 meshopt_computeSphereBounds 的层级包围球构建与 DAG 优化
c++·算法·图形渲染