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];
    }
};
相关推荐
程序猿Eason26 分钟前
U587038 背包 题解
c++·算法·动态规划
爱吃芒果的蘑菇27 分钟前
C++之WebSocket初体验
网络·c++·websocket·网络协议
Tipriest_32 分钟前
C++ 中 using 的使用方法详解
c++·using
potato_may39 分钟前
第18讲:C语言内存函数
c语言·数据结构·算法
顾晨阳——1 小时前
C/C++字符串
c语言·c++·字符串
深耕AI1 小时前
【MFC实用技巧】对话框“边框”属性四大选项:None、Thin、Resizing、对话框外框,到底怎么选?
c++·mfc
ajassi20001 小时前
开源 C++ QT QML 开发(二十一)多媒体--视频播放
c++·qt·开源
dingzd951 小时前
TikTok推荐算法快速解析
算法·机器学习·web3·facebook·推荐算法·tiktok·instagram
仰泳的熊猫1 小时前
LeetCode:95. 不同的二叉搜索树 II
数据结构·c++·算法·leetcode
Nix Lockhart2 小时前
《算法与数据结构》第七章[算法4]:最短路径
c语言·数据结构·学习·算法·图论