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;
    }
}
相关推荐
武子康14 分钟前
大数据-274 Spark MLib - 基础介绍 机器学习算法 剪枝 后剪枝 ID3 C4.5 CART
大数据·人工智能·算法·机器学习·语言模型·spark-ml·剪枝
Thanks_ks32 分钟前
深入链表剖析:从原理到 C 语言实现,涵盖单向、双向及循环链表全解析
数据结构·链表·c 语言·双向链表·单向链表·循环链表·算法与编程
moz与京43 分钟前
【数据结构】字符串操作整理(C++)
开发语言·数据结构·c++
爱coding的橙子2 小时前
每日算法刷题Day19 5.31:leetcode二分答案3道题,用时1h
算法·leetcode·职场和发展
初遇你时动了情3 小时前
dart常用语法详解/数组list/map数据/class类详解
数据结构·flutter·list
地平线开发者3 小时前
征程 6EM 常见 QConfig 配置解读与示例
算法·自动驾驶
GEEK零零七4 小时前
Leetcode 1908. Nim 游戏 II
算法·leetcode·博弈论
sbc-study4 小时前
混沌映射(Chaotic Map)
开发语言·人工智能·python·算法
Magnum Lehar4 小时前
vulkan游戏引擎game_types.h和生成build.bat实现
java·算法·游戏引擎
Christophe Chen4 小时前
strcat及其模拟实现
c语言·算法