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)

相关推荐
兰令水22 分钟前
leecodecode【区间DP+树形DP】【2026.6.10打卡-java版本】
java·算法·leetcode
8Qi81 小时前
LeetCode 4:寻找两个正序数组的中位数 —— 二分查找法
java·算法·leetcode·职场和发展·二分查找
8Qi82 小时前
LeetCode 32:最长有效括号 —— 栈 + 标记法 题解
java·数据结构·算法·leetcode·职场和发展··括号匹配
Tairitsu_H2 小时前
[LC优选算法#3] 滑动窗口 | 将x减到0的最⼩操作数 | ⽔果成篮 | 字⺟异位词
c++·算法·leetcode·滑动窗口
洛水水2 小时前
【力扣100题】76.搜索插入位置
数据结构·算法·leetcode
wabs6663 小时前
关于动态规划【力扣343.整数拆分的递推公式怎么理解?】
算法·leetcode·动态规划
承渊政道4 小时前
【MySQL数据库学习】MySQL基本查询(下)
数据库·学习·mysql·leetcode·bash·数据库开发·数据库系统
洛水水5 小时前
【力扣100题】78.在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
洛水水5 小时前
【力扣100题】77.搜索二维矩阵
算法·leetcode·矩阵
小欣加油14 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展