74. 搜索二维矩阵

74. 搜索二维矩阵

题目描述: 给你一个满足下述两条属性的 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
  • -10^4 <= matrix[i][j], target <= 10^4

二分思路:

  1. 二分查找:使用 leftright 两个指针表示搜索区间,初始值分别为 0 和 m * n - 1

  2. 在循环中,计算中间索引 mid。然后使用公式 x = mid / ny = mid % n++将一维索引转换回二维坐标。++

  3. 比较矩阵中位置 (x, y) 的值与目标值 target 的大小关系:

    • 如果相等,说明找到了目标值,返回 true
    • 如果矩阵中的值小于目标值,说明目标值在右半部分,将 left 指针移到 mid + 1
    • 如果矩阵中的值大于目标值,说明目标值在左半部分,将 right 指针移到 mid - 1
  4. 如果在循环结束时仍未找到目标值,说明不存在,返回 false

关键点是进行二分查找。这样可以在 O(log(m*n)) 的时间复杂度内完成搜索,相比直接遍历整个矩阵的方法效率要高。利用了矩阵是有序排列的这一特性,通过二分查找的方式快速定位目标值的位置,从而提高了搜索效率。

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int m = matrix.length;
        int n = matrix[0].length;

        if (target < matrix[0][0] || target > matrix[m - 1][n - 1]) {
            return false;
        }

        int left = 0, right = m * n - 1;
        int mid = 0;
        while (left <= right) {
            mid = (left + right) / 2;
            int x = mid / n;
            int y = mid % n;

            if (matrix[x][y] == target) {
                return true;
            } else if (matrix[x][y] < target) {
                left = mid + 1;
            } else {
                right = mid - 1;
            }
        }
        return false;
    }
}
相关推荐
Cosmoshhhyyy22 分钟前
《Effective Java》解读第39条:注解优先于命名模式
java·开发语言
亓才孓27 分钟前
[SpringIOC]NoSuchBeanDefinitionException
java·spring
追随者永远是胜利者35 分钟前
(LeetCode-Hot100)20. 有效的括号
java·算法·leetcode·职场和发展·go
瓦特what?1 小时前
快 速 排 序
数据结构·算法·排序算法
前路不黑暗@1 小时前
Java项目:Java脚手架项目的文件服务(八)
java·开发语言·spring boot·学习·spring cloud·docker·maven
niuniudengdeng1 小时前
基于时序上下文编码的端到端无文本依赖语音分词模型
人工智能·数学·算法·概率论
hetao17338371 小时前
2026-02-13~16 hetao1733837 的刷题记录
c++·算法
毅炼1 小时前
Java 集合常见问题总结(3)
java·开发语言·后端
百锦再2 小时前
Java多线程编程全面解析:从原理到实战
java·开发语言·python·spring·kafka·tomcat·maven
Cosmoshhhyyy3 小时前
《Effective Java》解读第38条:用接口模拟可扩展的枚举
java·开发语言