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;
    }
}
相关推荐
2301_822703207 小时前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙
cmpxr_7 小时前
【C】数组名、函数名的特殊
c语言·算法
KAU的云实验台7 小时前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
会编程的土豆7 小时前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
大熊背8 小时前
如何利用Lv值实现三级降帧
算法·自动曝光·lv·isppipeline
大尚来也8 小时前
驾驭并发:.NET多线程编程的挑战与破局之道
java·前端·算法
向阳而生,一路生花8 小时前
深入浅出 JDK7 HashMap 源码分析
算法·哈希算法
君义_noip9 小时前
信息学奥赛一本通 4150:【GESP2509七级】⾦币收集 | 洛谷 P14078 [GESP202509 七级] 金币收集
c++·算法·gesp·信息学奥赛·csp-s
superior tigre9 小时前
NumPy 基础使用方法(基础+矩阵运算+Attention)
线性代数·矩阵·numpy