二分查找-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];
    }

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

相关推荐
自信的小螺丝钉4 小时前
Leetcode 146. LRU 缓存 哈希表 + 双向链表
leetcode·缓存·散列表
西阳未落5 小时前
C++基础(21)——内存管理
开发语言·c++·面试
超级大福宝5 小时前
使用 LLVM 16.0.4 编译 MiBench 中的 patricia遇到的 rpc 库问题
c语言·c++
wangjialelele5 小时前
Linux中的线程
java·linux·jvm·c++
hsjkdhs7 小时前
万字详解C++之构造函数析构函数
开发语言·c++
SELSL8 小时前
SQLite3的API调用实战例子
linux·数据库·c++·sqlite3·sqlite实战
什么半岛铁盒8 小时前
C++项目:仿muduo库高并发服务器-------Channel模块实现
linux·服务器·数据库·c++·mysql·ubuntu
闭着眼睛学算法8 小时前
【华为OD机考正在更新】2025年双机位A卷真题【完全原创题解 | 详细考点分类 | 不断更新题目 | 六种主流语言Py+Java+Cpp+C+Js+Go】
java·c语言·javascript·c++·python·算法·华为od
ShineSpark9 小时前
C++面试11——指针与引用
c++·面试
杨小码不BUG9 小时前
CSP-J/S初赛知识点精讲-图论
c++·算法·图论··编码·csp-j/s初赛