leetcode240——搜索二维矩阵(medium)
一、题目描述
编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target。该矩阵具有以下特性:
- 每行的元素从左到右升序排列。
- 每列的元素从上到下升序排列。
示例:
现有矩阵 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。
给定 target = 20,返回 false。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/search-a-2d-matrix-ii
二、题解
方法一:暴力搜索法
方法一最容易想到,直接使用两个for循环遍历矩阵,当遇到与target相等的值时直接返回True即可。此法显然不是出题人想要的结果。
完成时间:2020.05.07
class Solution:
def searchMatrix(self, matrix, target):
"""
:type matrix: List[List[int]]
:type target: int
:rtype: bool
"""
for i in range(len(matrix)):
for j in range(len(matrix[0])):
if matrix[i][j] == target:
return True
return False
方法一使用了两趟循环:
时间复杂度:\(O(m * n)\) ,\(m\)指的是矩阵行数,\(n\)指的是矩阵列数。
空间复杂度:\(O(1)\)。
方法二:二分查找
方法二是对方法一的优化。由于矩阵的行和列都已经排好序,那么可以利用二分查找加快目标值的查找速度。具体做法是当按行遍历矩阵时,使用二分查找法对每行进行查找。
注意:
- 二分查找算法里面有很多细节需要注意,不然极容易出错。
完成时间:2020.05.09
class Solution:
def searchMatrix(self, matrix, target):
"""
:type matrix: List[List[int]]
:type target: int
:rtype: bool
"""
# 矩阵为空,直接返回False
if not matrix:
return False
rows = len(matrix)
columns = len(matrix[0])
for i in range(rows):
left = 0
right = columns - 1 # 注意
while left <= right: # 注意要带等号,不然当数组只有一个值时,可能会漏掉结果
mid = (left + right) // 2
if matrix[i][mid] > target:
right = mid - 1
elif matrix[i][mid] == target:
return True
elif matrix[i][mid] < target:
left = mid + 1
return False
方法二使用了两趟循环:
时间复杂度:for循环的时间复杂度为\(O(m)\) ,\(m\)指的是矩阵行数,while循环的时间复杂度为 \(O(\log_{2}n)\),n为矩阵的列数,所以总的时间复杂度为\(O(m*\log_{2}n)\);
空间复杂度:\(O(1)\)。
方法三:利用本题矩阵的特点
既然题目告诉我们矩阵每行的元素从左到右升序排列,每列的元素从上到下升序排列,那么我们可以利用这一特性来巧妙解题。
- 首先设置变量row表示行标,col表示列标,将row的初始值设为0,表示第一行,将col的初始值设为矩阵最后一列的下标;
- 然后使用一个while循环遍历矩阵,若matrix[row][col] > target成立时,说明当前值比目标值target大,列标col需要左移来找到更小的值与target相比较;若matrix[row][col] < target成立时,说明当前值比目标值target小,行标row需要下移来找到更大的值与target相比较;若matrix[row][col] == target成立时,说明找到了目标值target,直接返回True即可;
- 最后,若遍历结束仍然没有找到目标值target,说明矩阵中不存在目标值taregt,返回False即可。
注意:
- 与目标值比较的初始值选取的位置必须在矩阵的左下角和右上角处
完成时间:2020.05.07
class Solution:
def searchMatrix(self, matrix, target):
"""
:type matrix: List[List[int]]
:type target: int
:rtype: bool
"""
if not matrix:
return False
row, col = 0, len(matrix[0]) - 1
while row < len(matrix) and col >= 0:
if matrix[row][col] > target:
col -= 1
elif matrix[row][col] < target:
row += 1
else:
return True
return False
方法三使用了一趟循环:
时间复杂度:\(O(m + n)\) ,\(m\)指的是矩阵行数,\(n\)指的是矩阵列数。row的最大值不超过矩阵行数m,col的最大值不超过矩阵列数n。
空间复杂度:\(O(1)\)。
leetcode240——搜索二维矩阵(medium)的更多相关文章
- leetcode-240搜索二维矩阵II
搜索二维矩阵II class Solution: def searchMatrix(self, matrix, target): """ :type matrix: Li ...
- leetcode240 搜索二维矩阵 II
题目: 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性: 每行的元素从左到右升序排列. 每列的元素从上到下升序排列. 示例: 现有矩阵 ma ...
- [Swift]LeetCode240. 搜索二维矩阵 II | Search a 2D Matrix II
Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...
- lintcode:搜索二维矩阵II
题目 搜索二维矩阵 II 写出一个高效的算法来搜索m×n矩阵中的值,返回这个值出现的次数. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每一列的整数从上到下是排序的. 在每一行或每一列中没 ...
- lintcode :搜索二维矩阵
题目: 搜索二维矩阵 写出一个高效的算法来搜索 m × n矩阵中的值. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每行的第一个数大于上一行的最后一个整数. 样例 考虑下列矩阵: [ [1 ...
- LintCode-38.搜索二维矩阵 II
搜索二维矩阵 II 写出一个高效的算法来搜索m×n矩阵中的值,返回这个值出现的次数. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每一列的整数从上到下是排序的. 在每一行或每一列中没有重复 ...
- LeetCode74.搜索二维矩阵
74.搜索二维矩阵 描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 示 ...
- LeetCode:搜索二维矩阵【74】
LeetCode:搜索二维矩阵[74] 题目描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的 ...
- Leetcode 240.搜索二维矩阵II
搜索二维矩阵II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性: 每行的元素从左到右升序排列. 每列的元素从上到下升序排列. 示例: 现有 ...
随机推荐
- Linux终端命令格式
01.终端命令格式 command [-options] [parameter] 说明: command:命令名,响应功能的英文单词或单词的缩写 [-options]:选项,可用来对命令进行控制,也可 ...
- mysql优化之分区
mysql分区类型 日常开发中我们经常会遇到大表的情况,所谓的大表是指存储了百万级乃至千万级条记录的表.这样的表过于庞大,导致数据库在查询和插入的时候耗时太长,性能低下,如果涉及联合查询的情况,性能会 ...
- secureCRT常用操作
直接在网上搜索下载 连接 选择协议 Telnet Telnet连接时,进入输入密码 串口 连接串口后,查看本机连接的串口号 新建的时候,选择相同的串口号 RTS需要勾选掉 外观字体 选项 => ...
- Xss Game挑战
前言 最新学习了下xss的更深入的东西,学习了一波浏览器解析机制和XSS向量编码的知识. 这里就些xss的练习题巩固知识 学习的话结合如下两篇文章看,从例子和基础原理层面都有: http://boba ...
- XML外部实体注入[转载]
前言 对于xxe,深入的太少,一般做题也是复制payload再修改,没有了解过内部的结构规范等.这里转载了一篇先知社区的文章,排版了一下适合博客样式.文章总结的很好,结合了很多篇的博客文章,看完也是对 ...
- Stream—一个早产的婴儿
当你会关注这篇文章时,那么意味着你对Stream或多或少有些了解,甚至你在许多业务中有所应用.正如你所知,业界对Stream.lambda褒贬不一,有人认为它是银弹,也有人认为其降低了代码的可读性.事 ...
- .NET 4 实践 - 使用dynamic和MEF实现轻量级的AOP组件 (4)
转摘 https://www.cnblogs.com/niceWk/archive/2010/07/23/1783394.html 借花献佛 前面我们介绍了构成DynamicAspect绝大部分的类, ...
- Pycharm 操作数据库
view--->Tool Buttons,点击Pycharm右侧的Database 1.连接数据库 2.建立一个表,添加数据 通过以上操作把用户名和密码储存到了数据库中 3.连 ...
- 如何用hugo 搭建博客
1,Hugo 简介 搭建个人博客有很多开源的博客框架,我们要介绍的框架叫作Hugo.Hugo 是一个基于Go 语言的框架,可以快速方便的创建自己的博客. Hugo 支持Markdown 语法,我们可以 ...
- Linux系统管理第六次作业 进程和计划任务管理
1.通过ps命令的两种选项形式查看进程信息 [root@localhost ~]# ps aux USER PID %CPU %MEM VSZ RSS TTY STA ...