力扣74(java&python)-搜索二维矩阵(中等)
题目:
编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值。该矩阵具有如下特性:
每行中的整数从左到右按升序排列。
每行的第一个整数大于前一行的最后一个整数。
示例 1:
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true
示例 2:
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
输出:false
提示:
- m == matrix.length
- n == matrix[i].length
- 1 <= m, n <= 100
- -104 <= matrix[i][j], target <= 104
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/search-a-2d-matrix
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路:
【两次二分】
根据题目意思,每一行从上到下是升序的,每一列从上到下都是升序的,这样的话就可以运用两次二分查找,先找到合适的行,再找到合适的列。
- 第一次二分:从第0列中的所有行开始找,先聚焦target在哪个具体的行row;
- 第二次二分:在找到行的基础上,去找到合适的列col,从而就能确定出target是否在二维矩阵中。
java代码:
- 1 class Solution {
- 2 public boolean searchMatrix(int[][] matrix, int target) {
- 4 int m = matrix.length, n = matrix[0].length;
- 5 //第一次二分先找到行号
- 6 int left = 0, right = m - 1;
- 7 while (left < right){
- 8 int mid = left + (right - left + 1) / 2;
- 9 if (target >= matrix[mid][0]){
- 10 left = mid;
- 11 }else{
- 12 right = mid - 1;
- 13 }
- 14 }
- 15 //循环结束时:left > right
- 16 int row = right;
- 17 if (matrix[row][0] > target) return false;
- 18 //第二次二分找到列
- 19 left = 0; right = n - 1;
- 20 while (left < right){
- 21 int mid = left + (right - left) / 2;
- 22 if (target == matrix[row][mid]) return true;
- 23 if (target > matrix[row][mid]){
- 24 left = mid + 1;
- 25 }else {
- 26 right = mid;
- 27 }
- 28 }
- 29 int col = right;
- 30 return matrix[row][col] == target;
- 31 }
- 32 }
python3代码:
- 1 class Solution:
- 2 def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
- 3 m, n = len(matrix), len(matrix[0])
- 4 left, right = 0, m - 1
- 5 while left <= right:
- 6 mid = left + (right - left) // 2
- 7 if target > matrix[mid][0]:
- 8 left = mid + 1
- 9 elif target < matrix[mid][0]:
- 10 right = mid - 1
- 11 else:
- 12 return True
- 13 row = right
- 14 left, right = 0, n-1
- 15 while left <= right:
- 16 mid = left + (right - left) // 2
- 17 if target > matrix[row][mid]:
- 18 left = mid + 1
- 19 elif target < matrix[row][mid]:
- 20 right = mid - 1
- 21 else:
- 22 return True
- 23 return False
【直接遍历】
遍历查找每个位置,看target是否出现。
java代码:
- 1 class Solution {
- 2 public boolean searchMatrix(int[][] matrix, int target) {
- 3 int m = matrix.length, n = matrix[0].length;
- 4 for (int i = 0; i < m; i++){
- 5 for (int j = 0; j < n; j++){
- 6 if (matrix[i][j] == target){
- 7 return true;
- 8 }
- 9 }
- 10 }
- 11 return false;
- 12 }
- 13 }
python代码:
- 1 class Solution:
- 2 def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
- 3 m, n = len(matrix), len(matrix[0])
- 4 for i in range(m):
- 5 for j in range(n):
- 6 if matrix[i][j] == target:
- 7 return True
- 8 return False
力扣74(java&python)-搜索二维矩阵(中等)的更多相关文章
- LeetCode(74):搜索二维矩阵
Medium! 题目描述: 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 ...
- Java实现 LeetCode 74 搜索二维矩阵
74. 搜索二维矩阵 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 1: ...
- LeetCode:搜索二维矩阵【74】
LeetCode:搜索二维矩阵[74] 题目描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的 ...
- LeetCode 74. 搜索二维矩阵(Search a 2D Matrix)
74. 搜索二维矩阵 74. Search a 2D Matrix 题目描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. ...
- 【leetcode】74. 搜索二维矩阵
题目链接:传送门 题目描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 ...
- Java实现 LeetCode 240 搜索二维矩阵 II(二)
240. 搜索二维矩阵 II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性: 每行的元素从左到右升序排列. 每列的元素从上到下升序排列. ...
- lintcode:搜索二维矩阵II
题目 搜索二维矩阵 II 写出一个高效的算法来搜索m×n矩阵中的值,返回这个值出现的次数. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每一列的整数从上到下是排序的. 在每一行或每一列中没 ...
- lintcode :搜索二维矩阵
题目: 搜索二维矩阵 写出一个高效的算法来搜索 m × n矩阵中的值. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每行的第一个数大于上一行的最后一个整数. 样例 考虑下列矩阵: [ [1 ...
- LeetCode 240. 搜索二维矩阵 II(Search a 2D Matrix II) 37
240. 搜索二维矩阵 II 240. Search a 2D Matrix II 题目描述 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性 ...
- LeetCode74.搜索二维矩阵
74.搜索二维矩阵 描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 示 ...
随机推荐
- 记录一次运行vue项目一直不成功的经历
参考:https://blog.csdn.net/qq_17162169/article/details/115718002 如果前端项目一直起不来,直接删除扩展文件夹试试 // npm安装vue y ...
- C++ 字面值的前缀和后缀
一般字符字面值用前缀,数字字面值用后缀: --C++ Primer第五版2.1.3
- 开源推荐|简洁且强大的开源堡垒机OneTerm
在运维的日常工作中,登陆服务器操作不可避免,为了更安全的管控服务器,但凡有点规模的公司都会上线堡垒机系统,堡垒机能够做到事前授权.事中监控.事后审计,同时也可以满足等保合规要求.提到堡垒机,大伙第一时 ...
- Chrome浏览器:The request client is not a secure context and the resource is in more-private address ...
1.概述 新版的chrome浏览器会校验发起端的域名和访问资源的域名直接的关系,如果客户端发起域名比访问资源所在的域名更public(开放),会导致The request client is not ...
- .NET Emit 入门教程:第六部分:IL 指令:1:概要介绍
前言: 在之前的文章中,我们完成了前面五个部分的内容学习,包括: 第一部分:Emit介绍 第二部分:构建动态程序集 第三部分:构建模块(Module) 第四部分:构建类型(Type) 第五部分:动态生 ...
- 基于proteus的555的门铃计数电路
基于proteus的555的门铃计数电路 1.实验原理 555定时器可以作为单稳态触发器完成计数所需的时钟.门铃工作时,需要进行一次计数.计数器使用前面使用的4026就可以将结果直接显示在数码管上. ...
- KingbaseES V8R6 集群运维系列--sys_monitor.sh stop关闭集群分析
案例说明: 对于KingbaseES V8R6集群关闭整个集群通过执行'sys_monitor.sh stop'命令完成,本案例解析了在执行'sys_monitor.sh stop'后,数据库的关闭方 ...
- kubeadm init cannot find network namespace 错误
使用 kubeadm 安装好 weave 网络插件之后,查看 kubelet 输出信息发现如下错误: 4月 25 13:51:48 k8s-master kubelet[1232730]: I0425 ...
- MySQL数据库维护和改善性能
备份数据 由于MySQL数据库是基于磁盘的文件,普通的备份系统和例程就能备份MySQL的数据.但是,由于这些文件总是处于打开和使用状态,普通的文件副本备份不一定总是有效.下面列出这个问题的可能解决 ...
- VS2022+QT5.14.2开发VS QT Tool的使用
1.安装环境vs2022+QT5.14.2 qt vs tool (vsaddin)的使用遇到的坑 1.安装qt-vsaddin-msvc2022-3.0.2.vsix 安装失败 2.安装qt-vsa ...