LeetCode 分类刷题:74. 搜索二维矩阵

题目

给你一个满足下述两条属性的 m x n 整数矩阵:

  • 每行中的整数从左到右按非严格递增顺序排列。
  • 每行的第一个整数大于前一行的最后一个整数。

给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false

解析

由于矩阵的每一行是递增的,且每行的第一个数大于前一行的最后一个数,如果把矩阵每一行拼在一起,我们可以得到一个递增数组。

例如示例 1,三行拼在一起得

a=[1,3,5,7,10,11,16,20,23,30,34,60]
由于这是一个有序数组,我们可以用二分查找判断 target 是否在 matrix 中。

一般地,有

  • a[i]=matrix[ ⌊i/n⌋ ][ i mod n ]

作者:灵茶山艾府

链接:https://leetcode.cn/problems/search-a-2d-matrix/submissions/668071757/

来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

答案

自己写的

python 复制代码
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        row = len(matrix)
        col = len(matrix[0])
        for i in range(row):    # 遍历每一行,进行二分查找
            left = -1
            right = col - 1
            if matrix[i][right] < target:    # 当前行最大值小于target,直接跳至下一行
                continue
            while left + 1 < right:
                mid = (left + right) // 2
                if matrix[i][mid] < target:    # left恒小于target,right恒大于等于target
                    left = mid
                else:
                    right = mid
            if matrix[i][right] == target:    # right指向第一个大于等于target元素
                return True
        return False

灵神答案

python 复制代码
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        m, n = len(matrix), len(matrix[0])
        left, right = -1, m * n
        while left + 1 < right:
            mid = (left + right) // 2
            x = matrix[mid // n][mid % n]
            if x == target:
                return True
            if x < target:    # left恒指向小于target的元素,right恒指向大于target的元素
                left = mid    # target的搜索范围为开区间(left, right)
            else:
                right = mid 
        return False

复杂度分析

我的答案:

时间复杂度:O(mlog(n)),其中 m 和 n 分别为 matrix 的行数和列数。

空间复杂度:O(1)。

灵神答案:

时间复杂度:O(log(mn)),其中 m 和 n 分别为 matrix 的行数和列数。

空间复杂度:O(1)。

作者:灵茶山艾府

链接:https://leetcode.cn/problems/search-a-2d-matrix/submissions/668071757/

来源:力扣(LeetCode)

相关推荐
setmoon21415 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
sqyno1sky15 小时前
高级爬虫技巧:处理JavaScript渲染(Selenium)
jvm·数据库·python
sprite_雪碧15 小时前
排版类问题(机试高频)
c语言·数据结构·算法
暮冬-  Gentle°15 小时前
设计模式在C++中的实现
开发语言·c++·算法
2501_9083298515 小时前
实时音频处理C++实现
开发语言·c++·算法
dapeng287015 小时前
移动语义与完美转发详解
开发语言·c++·算法
2401_8845632415 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
2501_9181269115 小时前
学习所有python写浏览器的语句
开发语言·python·学习
bbbb36515 小时前
算法工程中的可扩展性与分布式实现方案的技术7
算法
Shining059615 小时前
AI 编译器系列(六)《Stable Diffusion 在 InfiniTensor 推理框架中的适配与工程实践》
人工智能·算法·stable diffusion·大模型·图像生成·ai编译器·infinitensor