算法24.0

153. 寻找旋转排序数组中的最小值 - 力扣(LeetCode)

自己的理解:

如果题目表现出来明显的二段性 可以考虑用二分算法

为什么C--D[i]<=nums[n-1]?

因为c--d里面的元素 有可能包含着d 所以是小于等于

还有没有别的二段性?

AB段的元素都比A大 CD段的元素都比A小 选择A点的值作为参照物

这个时候需要边界情况的考虑 如果旋转之后是一个完整递增的数组(和原数组一样)

为什么当以A点为划分二段性是 出现这样的错误if(nums[mid]>=x) left=mid+1; //right = mid ;?

认真画图 就可以知道问题出在哪里

细节:

审题要认真审题 题目有些关键词是思路的提示(例如时间复杂度 例这道题里面的nums中所有整数互不相同)

二分算法画图的时候 要和题目信息相关

例如这道题 left和right的中间点mid 落到的是AB和CD里面 这样找就容易找到二分算法的条件

别人的讲解:

暴力解法: 遍历一遍数组 然后找到结果

优化暴力解法:

A--B C--D 这是明显的二段性 考虑用二分查找

这里的二段性是:AB中的元素大于D CD里面的元素小于D

A--B nums[i]>nums[n-1] C--D[i]<=nums[n-1]

开始二分查找 如果mid落在了ab上 mid小于ret 那么下一步是left=mid+1 (可以绕过去 因为ab里面并没有d)

如果mid落在了cd上 mid>ret 那么下一步是right=mid (right不可以绕过去 因为有可能跳过要查找的元素)

下面是思路图:

下面是题目、效果图和代码:

java 复制代码
class Solution 
{
    //选择A点为参照物
    public int findMin(int[] nums) 
    {  
        int left = 0 ,right = nums.length-1;
        int x = nums[left] ;//记录下A点的元素
        
        //特殊情况的处理
        if(nums[left]<nums[right])
        {
           return nums[left];
        }


        while(left<right)
        {
            int mid = left+(right-left)/2;
            
            if(nums[mid]>=x) left=mid+1; //right = mid ;
            else right = mid ;//left = mid + 1;
        }
        return nums[left];
    }
}
//特殊情况的处理:如果旋转一个循环呢  到时候结果是原数组
java 复制代码
class Solution 
{
    public int findMin(int[] nums) 
    {
       int left = 0,right = nums.length-1;
       int x =nums[right];//标记一下最后元素的位置 也就是思路图里面的D元素
       while(left<right)
       {
        int mid = left + (right-left)/2;
        if(nums[mid]>x) left = mid + 1;
        else right = mid ; 
       }
       return nums[left];
    }
}
//xiyu251103&1#3*6
相关推荐
kaikaile199512 分钟前
基于 MATLAB 的室内三维定位
算法
AGI前沿26 分钟前
AdamW的继任者?AdamHD让LLM训练提速15%,性能提升4.7%,显存再省30%
人工智能·算法·语言模型·aigc
Tan_Ying_Y27 分钟前
什么是垃圾回收算法 他的底层原理是什么?
算法
Xの哲學40 分钟前
Linux 分区表深度技术剖析
linux·网络·算法·架构·边缘计算
写写闲篇儿1 小时前
经典算法题剖析之传递信息(三)
算法
上不如老下不如小1 小时前
2025年第七届全国高校计算机能力挑战赛初赛 Python组 编程题汇总
开发语言·python·算法
小年糕是糕手1 小时前
【C++】类和对象(二) -- 构造函数、析构函数
java·c语言·开发语言·数据结构·c++·算法·leetcode
kupeThinkPoem2 小时前
跳表有哪些算法?
数据结构·算法
前端小L2 小时前
图论专题(二十一):并查集的“工程应用”——拔线重连,修复「连通网络」
数据结构·算法·深度优先·图论·宽度优先
88号技师2 小时前
2025年9月一区SCI-孤行尺蠖觅食优化算法Solitary Inchworm Foraging-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法