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

相关推荐
无风听海13 小时前
CBOW 模型中输入矩阵、输出矩阵与词表向量矩阵深入解析
人工智能·机器学习·矩阵
张祥64228890416 小时前
线性代数本质十笔记
笔记·线性代数·机器学习
ct97817 小时前
gl-matrix矩阵库
矩阵·gis·gl-matrix
技术民工之路18 小时前
MATLAB线性方程组,运算符、inv()、pinv()全解析
线性代数·算法·matlab
a35354138219 小时前
牛顿迭代法中的雅克比矩阵几何意义
线性代数·算法
FL1717131419 小时前
黎曼几何/黎曼流形/黎曼度规/黎曼度量
线性代数
(; ̄ェ ̄)。19 小时前
机器学习入门(九)为什么sklearn正规方程法矩阵不可逆却可以计算出结果
机器学习·矩阵·sklearn
小尧嵌入式20 小时前
【Linux开发二】数字反转|除数累加|差分数组|vector插入和访问|小数四舍五入及向上取整|矩阵逆置|基础文件IO|深入文件IO
linux·服务器·开发语言·c++·线性代数·算法·矩阵
Σίσυφος190020 小时前
视觉矩阵之 正交矩阵
人工智能·算法·矩阵
好奇龙猫20 小时前
【大学院-筆記試験練習:线性代数和数据结构(13)】
数据结构·线性代数