当前位置: 首页 > article >正文

【hot100】刷题记录(11)-搜索二维矩阵 II

题目描述:

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:

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

 

示例 1:

 

输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 5
输出:true

示例 2:

 

输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 20
输出:false

 

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= n, m <= 300
  • -109 <= matrix[i][j] <= 109
  • 每行的所有元素从左到右升序排列
  • 每列的所有元素从上到下升序排列
  • -109 <= target <= 109

 

我的作答:

和【hot100】刷题记录(9)-螺旋矩阵 的思路很像,都是分别循环行和列;本题的思路是因为元素是越往右和往下变大,所以从最右边和最下面开始遍历,从外往内推;

需要注意的是m和n有大小区分

class Solution(object):
    def searchMatrix(self, matrix, target):
        """
        :type matrix: List[List[int]]
        :type target: int
        :rtype: bool
        """
        if not matrix and target: return False
        if not matrix and not target: return True
        starti, startj = 0, 0
        offset = 1
        m, n = len(matrix), len(matrix[0])
        while starti<=m-offset and startj<=n-offset:
            for i in range(starti, m-offset+1): #检查每行最后一个元素
                if matrix[i][n-offset]<target:
                    starti = i+1
                elif matrix[i][n-offset]==target:
                    return True
                else: break    
            for j in range(startj, n-offset+1): #检查每列最后一个元素
                if matrix[m-offset][j]<target:
                    startj = j+1
                elif matrix[m-offset][j]==target:
                   return True 
                else: break  
            offset += 1
        return False

 

参考:

class Solution(object):
    def searchMatrix(self, matrix, target):
        """
        :type matrix: List[List[int]]
        :type target: int
        :rtype: bool
        """
        return target in chain(*matrix)

chain(*matrix)itertools.chain 函数的一个用法,它用于将多个可迭代对象连接成一个长的可迭代对象。target in chain(*matrix) 的意思是检查 target 是否存在于 matrix 中的任何一个元素中。 

就是先把二维数组展平成一维数组,再查找。*matrix是把每一行的列表拼起来[[1,2] [2,3]]然后chain()是变成[1,2, 2, 3]接着查找。。。

 


http://www.kler.cn/a/530172.html

相关文章:

  • MongoDB深度解析与实践案例
  • PyTorch框架——基于深度学习YOLOv8神经网络学生课堂行为检测识别系统
  • Java篇之继承
  • 2501,编写dll
  • 自制虚拟机(C/C++)(二、分析引导扇区,虚拟机读二进制文件img软盘)
  • 【gRPC-gateway】option定义规则及HttpBody响应
  • AI源码加训练
  • 如何配置Java JDK
  • 8.原型模式(Prototype)
  • 代码随想录算法训练营第十六天| 二叉树4
  • 【论文复现】基于Otsu方法的多阈值图像分割改进鲸鱼优化算法
  • LLMs之OpenAI o系列:OpenAI o3-mini的简介、安装和使用方法、案例应用之详细攻略
  • 【每天学习一点点】通过使用@property装饰器来创建一个属性的getter和setter方法
  • 【周易哲学】生辰八字入门讲解(八)
  • STM32 DMA数据转运
  • leetcode 930. 和相同的二元子数组
  • 【人工智能】使用Python和Hugging Face构建情感分析应用:从模型训练到Web部署
  • ASP.NET Core Filter
  • 一文讲解Java中HashMap的put流程
  • 完全卸载mysql server步骤
  • Unity游戏(Assault空对地打击)开发(3) 摄像机的控制
  • C# 精炼题18道题(类,三木运算,Switch,计算器)
  • DeepSeek与OpenAI:谁是AI领域的更优选择?
  • 04树 + 堆 + 优先队列 + 图(D1_树(D8_B*树(B*)))
  • 书生大模型实战营7
  • openmv的端口被拆分为两个 导致电脑无法访问openmv文件系统解决办法 openmv USB功能改动 openmv驱动被更改如何修复