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

相关推荐
跨境卫士情报站3 小时前
用“渠道矩阵+内容节奏”把流量做成可控资产
大数据·人工智能·矩阵·产品运营·跨境电商·亚马逊
别或许3 小时前
01线性代数之行列式(知识总结)
线性代数
劈星斩月3 小时前
线性代数-3Blue1Brown《线性代数的本质》基变换(11)
线性代数·基变换
张祥6422889044 小时前
二次型:从线性代数到测量平差的桥梁
线性代数·算法·机器学习
sonadorje5 小时前
欧氏内积(Euclidean Inner Product)
线性代数·矩阵
geffen16881 天前
8K/4K无缝高清混合混插矩阵
矩阵
激动的兔子1 天前
Arcgis二次开发--评价单元综合限制级别判断矩阵工具
线性代数·arcgis·矩阵
geffen16881 天前
4K@60Hz高清无缝混合插卡矩阵8x8 16x16 32x32 40x40 80x80
矩阵
ScilogyHunter1 天前
CW方程的向量形式与解析形式
算法·矩阵·控制
辰尘_星启2 天前
[线性代数]矩阵/向量求导为什么要区别分子布局和分母布局
神经网络·线性代数·数学·矩阵·控制·导数