Day25力扣打卡

打卡记录

寻找旋转排序数组中的最小值(二分)

链接

由于是旋转排序数组,所以整个数组有两部分是递增的,选取右侧最后元素,即可将整个数组分为大于该元素和小于该元素,碰头地段即为最小值。

cpp 复制代码
class Solution {
public:
    int findMin(vector<int>& nums) {
        int n = nums.size();
        int l = 0, r = n - 1;
        while (l < r) {
            int mid = l + (r - l) / 2;
            if (nums[mid] <= nums[n - 1]) r = mid;
            else l = mid + 1;
        }
        return nums[l];
    }
};
相关推荐
im_AMBER几秒前
Leetcode 58 | 附:滑动窗口题单
笔记·学习·算法·leetcode
sin_hielo2 分钟前
leetcode 2154
算法·leetcode
Sunhen_Qiletian8 分钟前
YOLO的再进步---YOLOv3算法详解(上)
算法·yolo·计算机视觉
云泽80813 分钟前
C++ List 容器详解:迭代器失效、排序与高效操作
开发语言·c++·list
CodeAmaz13 分钟前
通用 List 分批切割并循环查询数据库工具类
java·数据结构·工具类·分页
xlq2232219 分钟前
15.list(上)
数据结构·c++·list
我不会插花弄玉40 分钟前
排序【由浅入深-数据结构】
c语言·数据结构
Elias不吃糖1 小时前
总结我的小项目里现在用到的Redis
c++·redis·学习
ANYOLY1 小时前
Sentinel 限流算法详解
算法·sentinel
AA陈超2 小时前
使用UnrealEngine引擎,实现鼠标点击移动
c++·笔记·学习·ue5·虚幻引擎