leetcode刷题记录(九十)——74. 搜索二维矩阵

(一)问题描述

74. 搜索二维矩阵 - 力扣(LeetCode)74. 搜索二维矩阵 - 给你一个满足下述两条属性的 m x n 整数矩阵: * 每行中的整数从左到右按非严格递增顺序排列。 * 每行的第一个整数大于前一行的最后一个整数。给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。 示例 1:https://assets.leetcode.com/uploads/2020/10/05/mat.jpg输入:matrix = \[1,3,5,7,10,11,16,20,23,30,34,60], target = 3输出:true示例 2:https://assets.leetcode-cn.com/aliyun-lc-upload/uploads/2020/11/25/mat2.jpg输入:matrix = \[1,3,5,7,10,11,16,20,23,30,34,60], target = 13输出:false 提示: * m == matrix.length * n == matrixi.length * 1 <= m, n <= 100 * -104 <= matrixij, target <= 104https://leetcode.cn/problems/search-a-2d-matrix/description/?envType=study-plan-v2&envId=top-100-liked

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

(二)解决思路

从两个方向使用二分法,先对矩阵的第一列使用二分法,找到最后一个小于等于target的元素,这个元素所在的行就是target可能存在的行,再对这一行使用二分法看能否找到target。

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        //先找在哪行
        int rowNum = matrix.length, colNum = matrix[0].length;
        
        if(target<matrix[0][0]||target>matrix[rowNum-1][colNum-1]) return false;

        int top=0, bottom=matrix.length-1;
        while(top<=bottom){
            int mid = (top+bottom)/2;
            if(target==matrix[mid][0]){
                  return true;
            }
            else if(target<matrix[mid][0]){
                  bottom=mid-1;
            }
            else{
                  top=mid+1;
            }
        }
        //如果第一列找到target这里就返回了,如果没找到,那target可能在的行就是搜索结束时top的前一行
        int row=top-1;

        //在这一行里用二分法判断在不在
        int left = 0, right = colNum-1;
        while(left<=right){
            int mid = (left+right)/2;
            if(target==matrix[row][mid]){
                return true;
            }
            else if(target<matrix[row][mid]){
                right=mid-1;
            }
            else{
                left=mid+1;
            }
        }
        return false;
    }

}
相关推荐
IT 行者34 分钟前
GitHub Spec Kit 实战(五):/speckit.tasks 怎么拆——Spec Kit 五部曲收官
java·ai编程·claude
(Charon)1 小时前
【C++ 面试高频基础:指针、引用、const、static、new/delete 总结】
java·开发语言
一只齐刘海的猫1 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
Yeats_Liao1 小时前
Feed流系统设计(三):数据模型与存储设计,从表结构到Redis收件箱
java·javascript·redis
JiaHao汤1 小时前
分布式事务方案全景:从理论到 Seata 落地
java·分布式·spring·spring cloud
海清河晏1111 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
金色熊族2 小时前
QTransform使用心得(二)--仿射变换、非仿射变换、矩阵
qt·线性代数·矩阵
liulilittle2 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
色空大师2 小时前
【debug调试详解-idea】
java·ide·intellij-idea·调试·远程调试
程序猿阿越2 小时前
AutoMQ源码(一)读、写、Compaction
java·后端·源码