【leetcode热题100】搜索二维矩阵

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

解法一 二分法

看到了有序序列,啥都不用想直接二分,只需要考虑到怎么把二分时候的下标转换为矩阵的行、列下标就可以了,很简单,用除法和求余就够了。

复制代码
public boolean searchMatrix(int[][] matrix, int target) {
    int rows = matrix.length;
    if (rows == 0) {
        return false;
    }
    int cols = matrix[0].length;
    int left = 0;
    int right = rows * cols - 1;
    while (left <= right) {
        int mid = (left + right) / 2;
        int temp = matrix[mid / cols][mid % cols];
        if (temp == target) {
            return true;
        } else if (temp < target) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }
    return false;
}

时间复杂度:O ( log ( n ) )。

空间复杂度:O ( 1 )。

相关推荐
要争气1 天前
5 二分查找算法应用
java·数据结构·算法
过往入尘土1 天前
深入探索现代前端开发:从基础到架构的完整指南
前端·人工智能·算法·前端框架
vir021 天前
翻转后1的数量(dp)
java·数据结构·算法
kyle~1 天前
机器视觉---ViBe算法
人工智能·算法·计算机视觉
CoovallyAIHub1 天前
如何在 2025 年构建强大的实时视频检测?
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
2025 年度 AI 行业百科《State of AI 2025》来了!推理元年、算力焦虑与价值回归
深度学习·算法·计算机视觉
寒冬没有雪1 天前
矩阵的翻转与旋转
c++·算法·矩阵
ʚ希希ɞ ྀ1 天前
二叉树的层序遍历
数据结构·算法
m0_743106461 天前
【VGGT-X】:尝试将VGGT用到3DGS重建中去
人工智能·算法·计算机视觉·3d·几何学
十二imin1 天前
霍夫丁不等式详解
算法·机器学习·概率论