240. 搜索二维矩阵 II

Problem: 240. 搜索二维矩阵 II

文章目录

思路

最干脆的方法是分别遍历矩阵的每一行和每一列,时间复杂度为 O ( n 2 ) O(n^2) O(n2),空间复杂度为 O ( 1 ) O(1) O(1)

由于行和列都是有序的,所以可以考虑二分查找,也可以分为两种方法

方法一:可以直接对行和列分别进行二分, 时间复杂度为 O ( m i n ( n , m ) l o g n ) O(min(n,m)logn) O(min(n,m)logn),空间复杂度为 O ( 1 ) O(1) O(1)

方法二:可以先对对角线进行二分,然后再分别对行和列进行二分,时间复杂度为 O ( m i n ( n , m ) l o g n ) O(min(n,m)logn) O(min(n,m)logn),空间复杂度为 O ( 1 ) O(1) O(1),但是这个要比方法一优化一些

解题方法

二分查找

复杂度

时间复杂度: O ( m i n ( n , m ) l o g n ) O(min(n,m)logn) O(min(n,m)logn)

空间复杂度: O ( 1 ) O(1) O(1)

Code

Python3 复制代码
class Solution:
    # 遍历行,行不变,变得是列
    def binary_search_row(self, matrix, target, begin, cols):
        l = begin
        r = cols
        while l < r:
            mid = l + r + 1 >> 1
            if matrix[begin][mid] <= target:
                l = mid
            else:
                r = mid - 1
        return begin<=l<=cols and matrix[begin][l] == target
        
    # 遍历列,列不变,行变
    def binary_search_col(self, matrix, target, begin, rows):
        l = begin
        r = rows
        while l < r:
            mid = l + r + 1 >> 1
            if matrix[mid][begin] <= target:
                l = mid
            else:
                r = mid - 1
        return begin<=l<=rows and matrix[l][begin] == target


    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        # 依次二分查找对角线、行和列
        m, n = len(matrix), len(matrix[0])
        # 遍历对角线
        min_val = min(m, n)
        l, r = 0, min_val - 1
        while l < r:
            mid = l + r + 1>> 1
            if matrix[mid][mid] <= target:
                l = mid
            else: 
                r = mid - 1
        if matrix[l][l] == target:
            return True
        
        for i in range(l + 1):
            if self.binary_search_row(matrix, target, i, n - 1) or self.binary_search_col(matrix, target, i, m - 1):
                return True
        return False
相关推荐
杰克尼30 分钟前
11. 盛最多水的容器
算法·leetcode·职场和发展
程序员Xu2 小时前
【OD机试题解法笔记】查找接口成功率最优时间段
笔记·算法
技术思考者3 小时前
Leetcode - 反转字符串
数据结构·算法·leetcode
SKYDROID云卓小助手4 小时前
无人设备遥控器之多设备协同技术篇
网络·人工智能·嵌入式硬件·算法·信号处理
Ghost-Face4 小时前
Ctorch开发日志——矩阵乘法优化及数学原理
矩阵·ctorch
熬了夜的程序员4 小时前
【华为机试】34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·华为od·华为·面试·golang
phltxy5 小时前
ArrayList与顺序表
java·算法
小拇指~6 小时前
梯度下降的基本原理
人工智能·算法·计算机视觉
艾莉丝努力练剑6 小时前
【C/C++】类和对象(上):(一)类和结构体,命名规范——两大规范,新的作用域——类域
java·c语言·开发语言·c++·学习·算法
TDengine (老段)7 小时前
TDengine 中 TDgp 中添加机器学习模型
大数据·数据库·算法·机器学习·数据分析·时序数据库·tdengine