leetcode hot100 74. 搜索二维矩阵 二分查找 medium


矩阵满足:

  1. 每行递增
  2. 下一行的第一个元素 > 上一行的最后一个元素

这意味着:整个矩阵如果按行"拉直",是一个严格递增的一维数组

所以可以直接用 二分查找。

不需要真的展开数组,只需要"映射索引"。

coffeescript 复制代码
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        m = len(matrix)
        n = len(matrix[0])

        left = 0
        right = m * n - 1

        while left <= right:
            mid = (left+right)//2
            row = mid // n   # 不需要真的展开数组,只需要"映射索引"。
            col = mid % n

            if matrix[row][col] > target:
                right = mid - 1
            elif matrix[row][col] < target:
                left = mid+1
            else:
                return True

        return False  # 找不到

时间复杂度 O(log(mn))

空间复杂度:O(1)

相关推荐
TracyCoder1231 小时前
LeetCode Hot100(60/100)——55. 跳跃游戏
算法·leetcode
Charlie_lll2 小时前
力扣解题-438. 找到字符串中所有字母异位词
后端·算法·leetcode
菜鸡儿齐3 小时前
leetcode-有效的括号
linux·算法·leetcode
We་ct3 小时前
LeetCode 102. 二叉树的层序遍历:图文拆解+代码详解
前端·算法·leetcode·typescript
苦藤新鸡3 小时前
65.搜索平移数组的最小值
算法·leetcode
重生之后端学习3 小时前
35. 搜索插入位置
java·数据结构·算法·leetcode·职场和发展·深度优先
Frostnova丶3 小时前
(1)LeetCode 1. 两数之和
leetcode·哈希算法
努力学算法的蒟蒻3 小时前
day96(2.25)——leetcode面试经典150
算法·leetcode·面试
吕司4 小时前
LeetCode Hot Code——找到字符串中所有字母异位词
算法·leetcode