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];
    }
};
相关推荐
码力码力我爱你1 天前
C++性能基准测试
开发语言·c++
小年糕是糕手1 天前
【C++】C++入门 -- 输入&输出、缺省参数
c语言·开发语言·数据结构·c++·算法·leetcode·排序算法
情怀姑娘1 天前
面试题---------------场景+算法
java·算法·mybatis
chbmvdd1 天前
week5题解
数据结构·c++·算法
用户12039112947261 天前
面试官最爱问的字符串反转:7种JavaScript实现方法详解
算法·面试
vir021 天前
小齐的技能团队(dp)
数据结构·c++·算法·图论
月夜的风吹雨1 天前
【C++红黑树】:自平衡二叉搜索树的精妙实现
开发语言·c++·红黑树
讨厌下雨的天空1 天前
Linux信号
linux·运维·c++
Star在努力1 天前
C语言复习八(2025.11.18)
c语言·算法·排序算法
赖small强1 天前
【Linux C/C++开发】第26章:系统级综合项目理论
linux·c语言·c++