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

一、题目解析

1.旋转的本质是把最后的n个元素放到起始位置

2.nums数组的各个元素值是不同的

3.时间复杂度要求0(logN)

二、算法原理

解法1:暴力解法 O(N)

给定一个赋值为INT_MAX的变量,遍历数组,记录最小值,由于数组长度为5000,所以暴力解法是可以通过的,遍历数组因此时间复杂度为O(N)

解法2:二分查找+D为分界点

二段性

解法3:二分查找+A为分界点

这里需要判断是否为旋转数组,因为存在旋转后与原数组一致的情况,所以需要判断nums[0]是否大于nums[n-1],大于则为旋转数组,反之则不是

三、代码示例

解法1:

cpp 复制代码
    int findMin(vector<int>& nums)//解法1
    {
        int ret = INT_MAX;
        for(auto e : nums)
        {
            if(e<ret) ret = e;
        }
        return ret;
    }

解法2:

cpp 复制代码
    int findMin(vector<int>& nums)//解法2:d为分界点
    {
        int n = nums.size();
        int left = 0,right = n-1;
        while(left < right)
        {
            int mid = left + (right - left)/2;
            if(nums[mid]>nums[n-1]) left = mid + 1;
            else right = mid;
        }
        return nums[right];
    }

解法3:

cpp 复制代码
    int findMin(vector<int>& nums)//解法3:a为分界点
    {
        int n = nums.size();
        if(nums[0]<nums[n-1]) return nums[0];
        int left = 0,right = n-1;
        while(left < right)
        {
            int mid = left + (right - left)/2;
            if(nums[mid]<nums[0]) right = mid;
            else left = mid + 1;
        }
        return nums[right];
    }

看到最后,如果对您有所帮助,还请点赞、收藏和关注,我们下期再见!

相关推荐
滴水成川12 分钟前
现代 C++ 开发工作流(VSCode / Cursor)
开发语言·c++·vscode·cursor
某个默默无闻奋斗的人12 分钟前
【矩阵专题】Leetcode48.旋转图像(Hot100)
java·算法·leetcode
张同学的IT技术日记17 分钟前
重构 MVC:让经典架构完美适配复杂智能系统的后端业务逻辑层(内附框架示例代码)
c++·后端·重构·架构·mvc·软件开发·工程应用
万能的小裴同学21 分钟前
星痕共鸣数据分析2
c++·数据分析
刚入坑的新人编程1 小时前
暑期算法训练.8
数据结构·c++·算法·面试·哈希算法
TalkU浩克1 小时前
C++中使用Essentia实现STFT/ISTFT
开发语言·c++·音频·istft·stft·essentia
小比卡丘2 小时前
【C++进阶】第7课—红黑树
java·开发语言·c++
序属秋秋秋5 小时前
《C++初阶之STL》【vector容器:详解 + 实现】
开发语言·c++·笔记·学习·stl
lixzest8 小时前
快速梳理遗留项目
java·c++·python
技术卷9 小时前
详解力扣高频SQL50题之1148. 文章浏览 I【入门】
sql·leetcode·oracle