74. 搜索二维矩阵

方法一:两次二分查找
cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>> matrix, int target) {
        auto row = upper_bound(matrix.begin(), matrix.end(), target, [](const int b, const vector<int> &a) {
            return b < a[0];
        });
        if (row == matrix.begin()) {
            return false;
        }
        --row;
        return binary_search(row->begin(), row->end(), target);
    }
};

方法二:一次二分查找

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

leetcode题解

相关推荐
hour_go2 小时前
张量、向量与矩阵:多维世界的数据密码
线性代数·矩阵
大佬,救命!!!2 小时前
3多维数组的矩阵乘法
线性代数·矩阵
2501_9181269119 小时前
用html5写一个可输入1-100行1-100列的矩阵计算器
线性代数·矩阵
lqjun08271 天前
平面的方程公式
线性代数·机器学习·平面
却道天凉_好个秋1 天前
OpenCV(九):NumPy中的矩阵的检索与赋值
opencv·矩阵·numpy
shimly1234562 天前
(done) 矩阵分块计算和分块转置
线性代数·矩阵
modest_laowang2 天前
矩阵李群的李代数的几何意义
线性代数·矩阵·抽象代数·拓扑学
寒冬没有雪2 天前
矩阵的翻转与旋转
c++·算法·矩阵
Miraitowa_cheems3 天前
LeetCode算法日记 - Day 68: 猜数字大小II、矩阵中的最长递增路径
数据结构·算法·leetcode·职场和发展·贪心算法·矩阵·深度优先
元基时代3 天前
视频图文矩阵发布系统企业
大数据·人工智能·矩阵