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

embedded/2025/2/6 20:38:54/

题目描述:

编写一个高效的算法来搜索 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 Falseif not matrix and not target: return Truestarti, startj = 0, 0offset = 1m, 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+1elif matrix[i][n-offset]==target:return Trueelse: break    for j in range(startj, n-offset+1): #检查每列最后一个元素if matrix[m-offset][j]<target:startj = j+1elif matrix[m-offset][j]==target:return True else: break  offset += 1return 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.ppmy.cn/embedded/160122.html

相关文章

Vim安装与配置教程(解决软件包Vim没有安装可候选)

Vim安装与配置教程&#xff08;解决软件包Vim没有安装可候选&#xff09;_软件包 vim 没有可安装候选-CSDN博客文章浏览阅读4.4k次&#xff0c;点赞70次&#xff0c;收藏47次。在Linux系统中&#xff0c;当我们使用apt-get install vim命令安装Vim 编辑器时&#xff0c;如果系统…

基于Flask的全国星巴克门店可视化分析系统的设计与实现

【FLask】基于Flask的全国星巴克门店可视化分析系统的设计与实现&#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 该系统采用Python作为主要开发语言&#xff0c;结合Flask框架进行后端开发&…

堆的实现——堆的应用(堆排序)

文章目录 1.堆的实现2.堆的应用--堆排序 大家在学堆的时候&#xff0c;需要有二叉树的基础知识&#xff0c;大家可以看我的二叉树文章&#xff1a;二叉树 1.堆的实现 如果有⼀个关键码的集合 K {k0 , k1 , k2 , …&#xff0c;kn−1 } &#xff0c;把它的所有元素按完全⼆叉树…

计算机网络笔记再战——理解几个经典的协议4

目录 IP——网际协议 IP地址 1. A类地址 2. B类地址 3. C类地址 4. D类地址&#xff08;组播地址&#xff09; 5. E类地址&#xff08;保留地址&#xff09; 特殊地址与私有地址 广播地址 IP多播 子网掩码 传统分类与CIDR/VLSM的对比 路由控制 默认路由 主机路由…

C++【iostream】数据库的部分函数功能介绍

在 C 编程世界中&#xff0c;iostream 库扮演着举足轻重的角色&#xff0c;它是 C 标准库的核心组成部分&#xff0c;为程序提供了强大的输入输出功能。无论是简单的控制台交互&#xff0c;还是复杂的文件操作&#xff0c;iostream 库都能提供便捷高效的解决方案。本文将深入剖…

【MySQL】第一弹---MySQL 在 Centos 7环境安装

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】【MySQL】 目录 1. 卸载不要的环境 2. 检查系统安装包 3. 卸载这些默认安装包 4. 获取mysql官方yum源 5. 安装mysql yum 源&am…

【漫话机器学习系列】073.黑塞矩阵(Hessian Matrix)

黑塞矩阵&#xff08;Hessian Matrix&#xff09; 黑塞矩阵&#xff08;Hessian Matrix&#xff09;是多变量数学中一个重要的概念&#xff0c;它是一个矩阵&#xff0c;包含了函数的二阶偏导数。黑塞矩阵在优化问题、机器学习以及深度学习中起着至关重要的作用&#xff0c;特…

数据分析系列--[11] RapidMiner,K-Means聚类分析(含数据集)

一、数据集 二、导入数据 三、K-Means聚类 数据说明:提供一组数据,含体重、胆固醇、性别。 分析目标:找到这组数据中需要治疗的群体供后续使用。 一、数据集 点击下载数据集 二、导入数据 三、K-Means聚类 Ending, congratulations, youre done.