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

相关推荐
luofeiju6 小时前
行列式的性质
线性代数·算法·矩阵
Morpheon9 小时前
从线性代数到线性回归——机器学习视角
线性代数·机器学习·数学建模·线性回归
2401_8812444011 小时前
斐波那契数列------矩阵幂法
线性代数·算法·矩阵
2401_8812444019 小时前
基础线性代数
python·线性代数·机器学习
灏瀚星空21 小时前
Python线性代数应用可视化:从矩阵变换到图像仿射
python·线性代数·矩阵
有梦想的骇客1 天前
书籍转圈打印矩阵(8)0604
线性代数·矩阵
2301_766536051 天前
刷leetcode hot100--矩阵6/1
算法·leetcode·矩阵
引量AI1 天前
如何用AI高效运营1000+Tiktok矩阵账号
人工智能·矩阵·自动化·tiktok矩阵·海外社媒
Gene_20222 天前
使用osqp求解简单二次规划问题
线性代数
一只小小汤圆2 天前
二维 根据矩阵变换计算镜像旋转角度
线性代数·机器学习·矩阵