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

[Java恶补day24] 74. 搜索二维矩阵

给你一个满足下述两条属性的 m x n 整数矩阵:
每行中的整数从左到右按非严格递增顺序排列。
每行的第一个整数大于前一行的最后一个整数。
给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。

示例 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
− 10 4 -10^4 104 <= matrix[i][j], target <= 10 4 10^4 104


知识点:
数组、矩阵、二分查找、排除法


解1(非常暴力):
核心思想:定义辅助数组存储所有元素(因为每一行的第一个元素大于上一行的最后一个元素,因此可以这么操作),然后对这个辅助数组进行二分查找

时间复杂度: O ( m n ) O(mn) O(mn)
空间复杂度: O ( m n ) O(mn) O(mn)

class Solution {public boolean searchMatrix(int[][] matrix, int target) {//获取行数、列数int m = matrix.length;int n = matrix[0].length;//定义辅助数组,存储所有元素int[] nums = new int[m * n];for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {nums[i * n + j] = matrix[i][j];}}//定义二分查找的指针int low = 0;int high = m * n - 1;//只要两个指针不重合,就继续循环while (low <= high) {//获取中位数int mid = (low + high) / 2;//判断是否存在if (nums[mid] == target) {return true;} else if (nums[mid] > target) {high = mid - 1;} else {low = mid + 1;}}//未找到return false;}
}

解2(排除法):
核心思想:同 #240. 搜索二维矩阵Ⅱ

时间复杂度: O ( m + n ) O(m+n) O(m+n)
空间复杂度: O ( 1 ) O(1) O(1)。未使用辅助数组,仅使用int类型的辅助变量。

class Solution {public boolean searchMatrix(int[][] matrix, int target) {//获取行数、列数int m = matrix.length;int n = matrix[0].length;//从右上角开始找int i = 0;int j = n - 1;//只要还有元素,就继续循环while (i < m && j >= 0) {//找到元素,返回if (matrix[i][j] == target) {return true;}//若当前元素>target,则遍历前面一列else if (matrix[i][j] > target) {j--;}//否则,遍历下面一行else {i++;}}//此时表明不存在元素return false;}
}

解3(二分查找):
核心思想:在形式上将矩阵所有元素放在一个数组中(因为每一行的第一个元素大于上一行的最后一个元素,因此可以这么操作),在实际上通过matrix[i/n][i%n]获取mid在matrix中对应的元素,然后使用二分查找

时间复杂度: O ( l o g ( m n ) ) O(log (mn)) O(log(mn))
空间复杂度: O ( 1 ) O(1) O(1)。未使用辅助数组。

class Solution {public boolean searchMatrix(int[][] matrix, int target) {//获取行数、列数int m = matrix.length;int n = matrix[0].length;//定义二分查找的指针int low = 0;int high = m * n - 1;//只要两个指针不重合,就继续循环while (low <= high) {//获取中位数int mid = (low + high) / 2;//获取矩阵对应的mid元素int item = matrix[mid / n][mid % n];//判断是否存在if (item == target) {return true;} else if (item > target) {high = mid - 1;} else {low = mid + 1;}}//未找到return false;}
}

参考:
1、灵神题解


文章转载自:

http://MGq2DhdM.xpzgg.cn
http://a1PLTnFq.xpzgg.cn
http://oSUv03vG.xpzgg.cn
http://T6FfUqEi.xpzgg.cn
http://lcQE3fTg.xpzgg.cn
http://RmWZ0ds7.xpzgg.cn
http://NvVwtRGy.xpzgg.cn
http://juIRba1H.xpzgg.cn
http://5QCYxpzA.xpzgg.cn
http://W4QzN5Gx.xpzgg.cn
http://mnQlvAD3.xpzgg.cn
http://MYvzMGi9.xpzgg.cn
http://dpobPepW.xpzgg.cn
http://KxNDNO5f.xpzgg.cn
http://jOZ75l9s.xpzgg.cn
http://FJZzLfUP.xpzgg.cn
http://GWf6xNZi.xpzgg.cn
http://beaWEaVE.xpzgg.cn
http://imt072J1.xpzgg.cn
http://0tgiteSp.xpzgg.cn
http://zvPnVcpi.xpzgg.cn
http://Jh6geHzE.xpzgg.cn
http://hP0YQXTX.xpzgg.cn
http://hocdqwRs.xpzgg.cn
http://serJzeHw.xpzgg.cn
http://xe7LDXau.xpzgg.cn
http://PYbXWGfD.xpzgg.cn
http://ADeIMguV.xpzgg.cn
http://xhSfPx4q.xpzgg.cn
http://SNEAhnss.xpzgg.cn
http://www.dtcms.com/a/248381.html

相关文章:

  • 【MacOS】系统数据占用超大存储空间,原因、定位、清理方式记录
  • vue常用框架,及更新内容
  • ServiceNow培训第1期
  • 50种3D效果演示(OpenGL)
  • openeuler 虚拟机:Nginx 日志分析脚本
  • 从开发到上线:iOS App混淆保护的完整生命周期管理(含Ipa Guard)
  • 直角坐标系-zernike多项式波面拟合
  • 初学时间复杂度
  • MRI中的“髓鞘探测器”:T1w/T2w比值揭秘
  • LeetCode 744.寻找比目标字母大的最小字母
  • 【C++特殊工具与技术】优化内存分配(六):运行时类型识别
  • 用 PlatformIO + ESP-IDF 框架开发 ESP32
  • 【Three.js】初识 Three.js
  • 很喜欢地理,高考选地理相关专业该怎么选?
  • 《数据安全法》学习(一)
  • BLEU 中的修正 n-gram 精确度 (Modified n-gram Precision)
  • Python自动化办公工具开发实践:打造智能报表生成系统的心得与洞见
  • CVPR2024迁移学习《Unified Language-driven Zero-shot Domain Adaptation》
  • qt配合海康工业相机取图开发
  • OpenCV 鼠标操作与响应之绘制ROI提取图像
  • grubby命令详解
  • 精益数据分析(102/126):SaaS用户流失率优化与OfficeDrop的转型启示
  • 【DeepSeek】移植计划
  • ImageSharp.Web 使用指南:高效处理ASP.NET Core中的图像
  • PHP设计模式实战:构建高性能API服务
  • 临时文件夹大量0字节xml问题排查
  • 比特币的运行机制---第2关:比特币的区块与网络
  • Token 的流动性:为什么它是项目的关键?
  • 为什么传统 Bug 追踪系统正在被抛弃?
  • 使用 C++/OpenCV 和 libevent 构建远程智能停车场管理系统