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 == matrix[i].length * 1 <= m, n <= 100 * -104 <= matrix[i][j], 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;
    }

}
相关推荐
Swift社区13 小时前
LeetCode 395 - 至少有 K 个重复字符的最长子串
算法·leetcode·职场和发展
Espresso Macchiato13 小时前
Leetcode 3710. Maximum Partition Factor
leetcode·职场和发展·广度优先遍历·二分法·leetcode hard·leetcode 3710·leetcode双周赛167
hz_zhangrl13 小时前
CCF-GESP 等级考试 2025年9月认证C++四级真题解析
开发语言·c++·算法·程序设计·gesp·c++四级·gesp2025年9月
代码小菜鸡66613 小时前
java 常用的一些数据结构
java·数据结构·python
火山灿火山13 小时前
详解AVL树旋转操作实现
数据结构·c++
止水编程 water_proof13 小时前
Java--网络编程(二)
java·开发语言·网络
少许极端13 小时前
算法奇妙屋(六)-哈希表
java·数据结构·算法·哈希算法·散列表·排序
羊羊小栈13 小时前
基于「多模态大模型 + BGE向量检索增强RAG」的新能源汽车故障诊断智能问答系统(vue+flask+AI算法)
vue.js·人工智能·算法·flask·汽车·毕业设计·大作业
Da Da 泓13 小时前
shellSort
java·数据结构·学习·算法·排序算法
武子康13 小时前
Java-148 深入浅出 MongoDB 聚合操作:$match、$group、$project、$sort 全面解析 Pipeline 实例详解与性能优化
java·数据库·sql·mongodb·性能优化·系统架构·nosql