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)

相关推荐
一叶落4387 小时前
题目:15. 三数之和
c语言·数据结构·算法·leetcode
big_rabbit05029 小时前
[算法][力扣222]完全二叉树的节点个数
数据结构·算法·leetcode
张李浩9 小时前
Leetcode 15三题之和
算法·leetcode·职场和发展
x_xbx10 小时前
LeetCode:206. 反转链表
算法·leetcode·链表
abant210 小时前
leetcode 138 复制随机链表
算法·leetcode·链表
做怪小疯子13 小时前
Leetcode刷题——8.重叠区间
算法·leetcode·职场和发展
_饭团13 小时前
指针核心知识:5篇系统梳理3
c语言·数据结构·算法·leetcode·面试·学习方法·改行学it
阿Y加油吧14 小时前
力扣打卡——day01
java·算法·leetcode
Tisfy14 小时前
LeetCode 1727.重新排列后的最大子矩阵:枚举矩形底边是哪一行 + 排序
算法·leetcode·矩阵
_饭团15 小时前
指针核心知识:5篇系统梳理2
c语言·笔记·学习·leetcode·面试·改行学it