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

相关推荐
AI科技星6 小时前
统一场论质量定义方程:数学验证与应用分析
开发语言·数据结构·经验分享·线性代数·算法
咚咚王者11 小时前
人工智能之数学基础 线性代数:第二章 向量空间
人工智能·线性代数
元周民11 小时前
非厄米矩阵高精度计算预先判定需要的计算精度(matlab)
线性代数·matlab·矩阵
java修仙传12 小时前
力扣hot100:搜索二维矩阵
算法·leetcode·矩阵
浅川.2514 小时前
xtuoj 矩阵
线性代数·矩阵
ACERT33314 小时前
05-矩阵理论复习第五章 向量与矩阵范数
python·算法·矩阵
前端小白在前进16 小时前
⭐力扣刷题:螺旋矩阵
算法·leetcode·矩阵
-一杯为品-1 天前
【机器人学|运动学与动力学】#1 齐次变换矩阵
线性代数·矩阵
胖咕噜的稞达鸭1 天前
算法入门:专题前缀和:一二维前缀和 寻找数组的中心下标 除自身以外数组的乘积 和为k的子数组 和可被k整除的子数组 连续数组 矩阵区域和
线性代数·算法·矩阵
拾贰_C2 天前
【数学 | 大学数学 | 考研数学 | 计算机】线性代数 | 矩阵论
线性代数·矩阵