【LeetCode 热题 100】搜索插入位置 / 搜索旋转排序数组 / 寻找旋转排序数组中的最小值

⭐️个人主页:@小羊 ⭐️所属专栏:LeetCode 热题 100 很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎 ~

目录


搜索插入位置

为什么最后可以直接 return l,如果没找到目标值,则会由 l > r 出循环。如果是由 r = mid - 1 出的循环,说明此时 mid == l 且所指位置就是要插入的位置;如果是由 l = mid + 1 出的循环,mid所指的元素刚好小于目标值,则出循环后l所指的就是需要插入的位置。

cpp 复制代码
class Solution {
public:
    int searchInsert(vector<int>& nums, int target) {
        int l = 0, r = nums.size() - 1;
        while (l <= r)
        {
            int mid = (l + r) / 2;
            if (nums[mid] > target) r = mid - 1;
            else if (nums[mid] < target) l = mid + 1;
            else return mid;
        }
        return l;
    }
};

搜索二维矩阵

每行进行一次二分查找。

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m = matrix.size(), n = matrix[0].size();
        for (int i = 0; i < m; i++)
        {
            int l = 0, r = n - 1;
            while (l <= r)
            {
                int mid = (l + r) / 2;
                if (matrix[i][mid] < target) l = mid + 1;
                else if (matrix[i][mid] > target) r = mid - 1;
                else return true;
            }
        }
        return false;
    }
};

将二维数组看作一维数组进行二分。

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m = matrix.size(), n = matrix[0].size();
        int l = 0, r = m * n - 1;
        while (l <= r)
        {
            int mid = l + (r - l) / 2;
            int t = matrix[mid / n][mid % n];
            if (t < target) l = mid + 1;
            else if (t > target) r = mid - 1;
            else return true;
        }
        return false;
    }
};

在排序数组中查找元素的第一个和最后一个位置

cpp 复制代码
class Solution {
public:
    vector<int> searchRange(vector<int>& nums, int target) {
        if (nums.empty()) return {-1, -1};
        int l = 0, r = nums.size() - 1;
        while (l < r)
        {
            int mid = l + (r - l) / 2;
            if (nums[mid] < target) l = mid + 1;
            else r = mid;
        }
        if (nums[l] != target) return {-1, -1};
        int begin = l;
        r = nums.size() - 1;
        while (l < r)
        {
            int mid = l + (r - l + 1) / 2;
            if (nums[mid] > target) r = mid - 1;
            else l = mid;
        }
        return {begin, r};
    }
};

搜索旋转排序数组

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int n = nums.size();
        int l = 0, r = n - 1;
        while (l <= r)
        {
            int mid = l + (r - l) / 2;
            if (nums[mid] == target) return mid;
            if (nums[0] <= nums[mid])
            {
                if (nums[0] <= target && nums[mid] > target) r = mid - 1;
                else l = mid + 1;
            }
            else
            {
                if (target <= nums[n - 1] && nums[mid] < target) l = mid + 1;
                else r = mid - 1;
            }
        }
        return -1;
    }
};

寻找旋转排序数组中的最小值

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];
    }
};

本篇文章的分享就到这里了,如果您觉得在本文有所收获,还请留下您的三连支持哦~

相关推荐
Tisfy几秒前
LeetCode 955.删列造序 II:模拟(O(mn)) + 提前退出
算法·leetcode·字符串·题解·遍历
im_AMBER6 分钟前
Leetcode 82 每个字符最多出现两次的最长子字符串 | 删掉一个元素以后全为 1 的最长子数组
c++·笔记·学习·算法·leetcode
姓蔡小朋友8 分钟前
后端面试八股文
面试·职场和发展
java修仙传10 分钟前
力扣hot100:旋转排序数组中找目标值
算法·leetcode·职场和发展
式51611 分钟前
量子力学基础(二)狄拉克符号与复数向量空间
人工智能·算法·机器学习
k***921621 分钟前
【Linux】进程概念(六):地址空间核心机制
linux·运维·算法
xu_yule24 分钟前
算法基础-字符串哈希
算法·哈希算法·散列表
lixzest26 分钟前
C++中经常用的头文件介绍
数据结构·c++·算法
保持低旋律节奏31 分钟前
linux——进程调度(时间片+优先级轮转调度算法O(1))
linux·运维·算法
狂炫冰美式1 小时前
当硅基神明撞上人类的“叹息之墙”:距离证明哥德巴赫猜想,AI还有多远?
前端·算法·架构