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;
    }
}
相关推荐
nike0good9 分钟前
Goodbye 2025 题解
开发语言·c++·算法
Sheep Shaun11 分钟前
STL中的unordered_map和unordered_set:哈希表的快速通道
开发语言·数据结构·c++·散列表
崇山峻岭之间11 分钟前
Matlab学习记录19
学习·算法·matlab
jllllyuz14 分钟前
基于帧差法与ViBe算法的MATLAB前景提取
开发语言·算法·matlab
optimistic_chen22 分钟前
【Redis 系列】常用数据结构---String类型
数据结构·数据库·redis·缓存·string
wen__xvn34 分钟前
代码随想录算法训练营DAY1第一章 数组part01
数据结构·算法·leetcode
爱编码的傅同学38 分钟前
【程序地址空间】页表的映射方式
c语言·数据结构·c++·算法
Mintopia40 分钟前
🧠 从零开始:纯手写一个支持流式 JSON 解析的 React Renderer
前端·数据结构·react.js
UID96221 小时前
[特殊字符] 无级变速传动(CVT)技术突破之道 | 易经×数学×工程的跨维度破解方案
算法·数学建模·开源
生信碱移1 小时前
神经网络单细胞预后分析:这个方法直接把 TCGA 预后模型那一套迁移到单细胞与空转数据上了!竟然还能做模拟敲除与预后靶点筛选?!
人工智能·深度学习·神经网络·算法·机器学习·数据挖掘·数据分析