LeetCode Hot100 搜索二维矩阵

给你一个满足下述两条属性的 m x n 整数矩阵:

  • 每行中的整数从左到右按非严格递增顺序排列。
  • 每行的第一个整数大于前一行的最后一个整数。

给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false

示例 1:

复制代码
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true

示例 2:

复制代码
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
输出:false

思路

第一次

两次二分查找,先找行,再找列,注意数组不要越界。复杂度上logmn

第二次

当一维数组做,复杂度同logmn

代码

第一遍

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int i = 0,j = matrix.size()-1;
        int m,row;
        while(i<=j)
        {
            m = i+ (j-i)/2;
            if(matrix[m][0] == target)
                return true;
            else if(matrix[m][0] > target)
            {
                j = m-1;
            }
            else
                i = m+1;
        }
        if((row = i-1) < 0)
            return false;
        i = 0;
        j = matrix[0].size()-1;
        while(i<=j)
        {
            m = i + (j-i)/2;
            if(matrix[row][m] == target)
                return true;
            else if(matrix[row][m] > target)
                j = m-1;
            else
                i = m+1;
        }
        return false;
    }
};

第二遍

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int i = 0,j = matrix.size()*matrix[0].size()-1;
        int m,size = matrix[0].size();
        int row,col;
        while(i<=j)
        {
            m = i+ (j-i)/2;
            row = m/size;
            col = m%size;
            if(matrix[row][col] == target)
                return true;
            else if(matrix[row][col] > target)
            {
                j = m-1;
            }
            else
                i = m+1;
        }
        return false;
    }
};
相关推荐
vibecoding日记9 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr213811 小时前
Verilog参数化游程编码RLE模块
算法
望易11 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络15 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术2 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望2 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法