【Python】Leetcode 240. 搜索二维矩阵 II - 削减矩阵+递归,击败88%

描述

  1. 搜索二维矩阵 II

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。

该矩阵具有以下特性:

每行的元素从左到右升序排列。

每列的元素从上到下升序排列。

思路

确定左右及上下限,削减矩阵,递归。

注意判断四个端点是否等于target,若有满足的返回true,否则判断左上角端点或右下角端点是否大于或小于target,满足则返回false,否则递归直到上下限溢出返回false。

可以证明,在以上判断条件下,每次递归都会导致矩阵被削减,时间复杂度为O(m+n)

复杂度

时间复杂度:

O(m+n)

空间复杂度:

O(1)

`class Solution:

def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:

l = 0

r = len(matrix[0])-1

t = 0

b = len(matrix)-1

return self.dfs(matrix,l,r,t,b,target)

复制代码
def dfs(self,matrix,l,r,t,b,target):
    print(l,r,t,b)
    if(r<l or b<t): return False
    if(matrix[t][l] == target or matrix[b][r] == target or matrix[t][r] == target or matrix[b][l] == target): return True
    if(matrix[t][l] > target): return False
    if(matrix[b][r] < target): return False
    n_r = r
    for i in range(r-l+1):
        if(matrix[t][r-i] <= target):
            n_r = r-i
            break
    
    n_l = l
    for i in range(r-l+1):
        if(matrix[b][l+i] >= target):
            n_l = l+i
            break
    
    n_b = b
    for i in range(b-t+1):
        if(matrix[b-i][l] <= target):
            n_b = b-i
            break
    
    n_t = t
    for i in range(b-t+1):
        if(matrix[t+i][r] >= target):
            n_t = t+i
            break

    return self.dfs(matrix,n_l,n_r,n_t,n_b,target)`
相关推荐
琢磨先生David4 小时前
Day1:基础入门·两数之和(LeetCode 1)
数据结构·算法·leetcode
多恩Stone5 小时前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
QQ4022054965 小时前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
百锦再5 小时前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
QQ5110082855 小时前
python+springboot+django/flask的校园资料分享系统
spring boot·python·django·flask·node.js·php
QQ_19632884755 小时前
Python-flask框架西山区家政服务评价系统网站设计与开发-Pycharm django
python·pycharm·flask
遥遥江上月5 小时前
Node.js + Stagehand + Python 部署
开发语言·python·node.js
B站计算机毕业设计超人5 小时前
计算机毕业设计Django+Vue.js音乐推荐系统 音乐可视化 大数据毕业设计 (源码+文档+PPT+讲解)
大数据·vue.js·hadoop·python·spark·django·课程设计
B站_计算机毕业设计之家5 小时前
电影知识图谱推荐问答系统 | Python Django系统 Neo4j MySQL Echarts 协同过滤 大数据 人工智能 毕业设计源码(建议收藏)✅
人工智能·python·机器学习·django·毕业设计·echarts·知识图谱
计算机专业码农一枚5 小时前
Python-flask框架基于推荐算法的在线课程推荐系统设计与实现-Pycharm django
python·flask·推荐算法