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
相关推荐
2601_9577867719 分钟前
短视频矩阵全链路自动化系统的技术架构与性能实测
矩阵·架构·自动化
技术小黑2 小时前
CNN算法实战系列03 | DenseNet121算法实战与解析
pytorch·深度学习·算法·cnn
wearegogog1232 小时前
三电平SVPWM逆变器仿真指南
单片机·算法
笨笨饿3 小时前
74_SysTick滴答定时器中断
c语言·开发语言·人工智能·单片机·嵌入式硬件·算法·学习方法
pkowner3 小时前
若依分页问题及解决方法
java·前端·算法
呃呃本4 小时前
算法题(栈)
算法
通信小呆呆4 小时前
基于 ADMM-MFOCUSS 的捷变频雷达扩展目标稀疏重构原理
算法·重构·信息与通信·信号处理·雷达
橙淮4 小时前
Java数组与链表:特性对比与应用场景
数据结构·算法
炽烈小老头4 小时前
【每天学习一点算法 2026/05/15】被围绕的区域
学习·算法·深度优先
芜湖xin4 小时前
【题解-洛谷】P1012 [NOIP 1998 提高组] 拼数
算法·贪心