搜索二维矩阵

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

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

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

示例 1:

复制代码
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true

思路:二维当一维处理,只进行一次二分查找

python 复制代码
from typing import List

#一次二分查找,假装二维数组是个一维数组
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        m, n = len(matrix), len(matrix[0])
        left, right = 0, m * n - 1
        while left <= right:
            mid = left + (right - left) // 2
            if matrix[mid//n][mid%n] == target:
                return True
            elif matrix[mid//n][mid%n] > target:
                right = mid - 1
            else:
                left = mid + 1
        return False
相关推荐
chh5632 小时前
从零开始学C++--类和对象
java·开发语言·c++·学习·算法
森屿~~2 小时前
PlatEMO 深度实战解析——从底层架构到 CMOPs 与 MMO 算法魔改
算法
郝学胜-神的一滴2 小时前
自动微分实战:梯度下降的迭代实现与梯度清零核心解析
人工智能·pytorch·python·深度学习·算法·机器学习
daad7772 小时前
std::vector insert
算法
炽烈小老头2 小时前
【每天学习一点算法 2026/04/07】快乐数
学习·算法
计算机安禾2 小时前
【数据结构与算法】第31篇:排序概述与插入排序
c语言·开发语言·数据结构·学习·算法·重构·排序算法
PILIPALAPENG2 小时前
第1周 Day 5:前端转型AI,回顾总结🎯
前端·人工智能·python
网路末端遗传因子2 小时前
CHO细胞培养中高乳酸与低产量的模式识别与分析
算法·机器学习·细胞培养·生物培养基开发
阿Y加油吧2 小时前
LeetCode 中等难度 | 回溯法经典题解:组合总和 & 括号生成
算法