64.搜索二维矩阵

给你一个满足下述两条属性的 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

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= m, n <= 100
  • -104 <= matrix[i][j], target <= 104

代码:

复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        //先二分每行首元素寻找最后一个小于等于target的值,r为行数
        int l = 0,r = matrix.length-1;
        while(l<r){
            int mid = (l+r+1)>>1;
            if(matrix[mid][0]<=target)l = mid;
            else r = mid-1;
        }
        //t即为最后一个小于等于target的元素所在的行
        int t = l;
        //重新初始化左右端点,r为列数
        l = 0;
        r = matrix[0].length-1;
        //二分第t行所有元素寻找最后一个小于等于target的值
        while(l<r){
            int mid = (l+r+1)>>1;
            if(matrix[t][mid] <= target)l = mid; 
            else r = mid-1;
        }
        //如果该值为target,直接返回true
        if(matrix[t][l] == target)return true;
        //否则返回false
        else return false;
    }
}
相关推荐
CoovallyAIHub1 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙1 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
CoovallyAIHub5 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
SparkX开源AI知识库5 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构
一语07166 小时前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法
哈里谢顿20 小时前
跳表(Skip List):简单高效的有序数据结构
数据结构
CoovallyAIHub1 天前
181小时视频丢给GPT-5,准确率只有15%——南大联合NVIDIA等五校发布多模态终身理解数据集
深度学习·算法·计算机视觉