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题解

相关推荐
西西弗Sisyphus22 分钟前
线性代数 - 二阶矩阵的行列式、向量叉积(Cross product)的模长与平行四边形面积的关系
线性代数·矩阵·行列式
西西弗Sisyphus16 小时前
线性代数 - 3 阶方阵的行列式 可视化
线性代数·矩阵·行列式·满秩·降秩
西西弗Sisyphus16 小时前
线性代数 - 矩阵乘法能换括号,不能换顺序;满足结合律,不满足交换律
线性代数·矩阵
gihigo199817 小时前
MATLAB中生成混淆矩阵
开发语言·matlab·矩阵
就不爱吃大米饭1 天前
Facebook矩阵引流:从防封到规模化运营的完整策略
线性代数·矩阵·facebook
西西弗Sisyphus1 天前
线性代数 - 从方程组到行列式
线性代数·矩阵·行列式·determinant·det
西西弗Sisyphus1 天前
线性代数 - 齐次线性方程组的解 与满秩/降秩的关系
线性代数·满秩·降秩
老黄编程1 天前
三维空间平面方程
线性代数·平面
FuckPatience2 天前
WPF MatrixTransform 矩阵参数的疑问?
线性代数·矩阵
从后端到QT2 天前
标量-向量-矩阵-基础知识
人工智能·机器学习·矩阵