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
相关推荐
近津薪荼9 分钟前
优选算法——分治(2):快速选择
算法
Z...........9 分钟前
(优选算法)斐波那契数列模型
数据结构·算法
zyjyyds11326 分钟前
和为0的四元组-双指针法(C语言实现)
c语言·数据结构·算法
炽烈小老头42 分钟前
【每天学习一点算法 2026/03/16】电话号码的字母组合
学习·算法
Lee川1 小时前
时空迷宫探险记:从O(1)到O(2^n)的算法进化论
算法·面试
KangJX1 小时前
Matrix获取卡顿堆栈 (Point Stack)
算法·客户端
靠沿1 小时前
【优选算法】专题十三——队列+宽搜(BFS)
算法·宽度优先
ccLianLian2 小时前
算法·字符串哈希
算法·哈希算法
SongYuLong的博客2 小时前
Linux IPC进程通信几种方法
linux·运维·算法
像污秽一样2 小时前
算法设计与分析-习题6.1
数据结构·算法