LeetCode hot 100—搜索二维矩阵

题目

给你一个满足下述两条属性的 m x n 整数矩阵:

  • 每行中的整数从左到右按非严格递增顺序排列。
  • 每行的第一个整数大于前一行的最后一个整数。

给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false

示例

示例 1:

复制代码
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true

示例 2:

复制代码
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
输出:false

分析

二分法

由于矩阵具有题目中所给的特性,我们可以将其看作一个有序的一维数组,使用二分查找算法。

初始化左右指针 leftright,分别指向一维数组的起始位置和结束位置。在 while 循环中,计算中间位置 mid,并通过 mid 计算出其在矩阵中的行 row 和列 col

如果中间位置的元素等于目标值 target,则返回 true

如果中间位置的元素小于目标值 target,则将左指针 left 移动到 mid + 1 的位置。

如果中间位置的元素大于目标值 target,则将右指针 right 移动到 mid - 1 的位置。

如果循环结束后仍未找到目标值,则返回 false

时间复杂度:O()

空间复杂度:O(1)

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m = matrix.size();
        int n = matrix[0].size();
        int left = 0, right = m * n - 1;
        while (left <= right) {
            int mid = left + (right - left) / 2;
            int row = mid / n;
            int col = mid % n;
            if (matrix[row][col] == target) {
                return true;
            } else if (matrix[row][col] < target) {
                left = mid + 1;
            } else {
                right = mid - 1;
            }
        }
        return false;
    }
};
相关推荐
重生之我是Java开发战士几秒前
【优选算法】前缀和:一二维前缀和,寻找数组的中心下标,除自身以外数组的乘积,和为K的子数组,和可被K整除的子数组,连续数组,矩阵区域和
线性代数·算法·矩阵
梵刹古音3 分钟前
【C语言】 循环结构
c语言·开发语言·算法
消失的旧时光-19436 分钟前
C++ 函数参数传递方式总结:什么时候用值传递、引用、const 引用?
开发语言·c++
一匹电信狗8 分钟前
【C++】CPU的局部性原理
开发语言·c++·系统架构·学习笔记·c++11·智能指针·新特性
bbq粉刷匠10 分钟前
Java-排序2
java·数据结构·排序算法
皮皮哎哟10 分钟前
冒泡排序与数组传递全解析 一维二维指针数组及二级指针应用指南
c语言·算法·冒泡排序·二维数组·指针数组·传参·二级指针
m0_5613596712 分钟前
C++代码冗余消除
开发语言·c++·算法
会开花的二叉树17 分钟前
吃透Reactor多线程:EventLoop_Channel_ThreadPool协作原理
开发语言·c++·tcp/ip·servlet
Jm_洋洋18 分钟前
【C++进阶】虚函数、虚表与虚指针:多态底层机制剖析
java·开发语言·c++
近津薪荼22 分钟前
优选算法——滑动窗口1(单调性)
c++·学习·算法