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

【LeetCode热题100】240. 搜索二维矩阵 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
− 1 0 9 -10^9 109 <= matrix[i][j] <= 1 0 9 10^9 109
每行的所有元素从左到右升序排列
每列的所有元素从上到下升序排列
− 1 0 9 -10^9 109 <= target <= 1 0 9 10^9 109

四.解题思路

解法1.直接遍历 O ( m n ) O(mn) O(mn) 没想到能过。。

解法2.对每行(有序)所以可以二分查找 O ( m l o g 2 n ) O(mlog _2n) O(mlog2n)

解法3.Z型查找 O ( m + n ) O(m+n) O(m+n) 没想到还能这么玩 GPT解释如下:

利用矩阵的两个属性:每行的元素从左到右升序排列,每列的元素从上到下升序排列。基于这两个属性,可以从矩阵的右上角(或左下角)开始搜索。
算法思路
从右上角开始搜索:

  1. 如果当前元素等于目标值,则返回true。 如果当前元素小于目标值,则移动到下一行(因为当前列的所有元素都将小于目标值)。
  2. 如果当前元素大于目标值,则移动到前一列(因为当前行的所有元素都将大于目标值)。
  3. 重复这些步骤,直到找到目标值或者搜索区域为空。

这种方法之所以有效,是因为它每次迭代都排除一行或一列,这样就可以在常数时间内将搜索空间减半,从而实现快速查找。

五.代码实现

Z型查找:解法3

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {if (matrix.empty()) return false;int rows = matrix.size(), cols = matrix[0].size();int row = 0, col = cols - 1;  // 从右上角开始while (row < rows && col >= 0) {if (matrix[row][col] == target) {return true;  // 找到目标值} else if (matrix[row][col] < target) {row++;  // 移动到下一行} else {col--;  // 移动到前一列}}return false;  // 搜索区域为空,未找到目标值}
};

解法1

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {for (vector<vector<int>>::iterator it = matrix.begin(); it != matrix.end(); it++){for (vector<int>::iterator itt = it->begin(); itt != it->end(); itt++){if (*itt == target)return true;}}return false;}
};

解法2

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {for (vector<vector<int>>::iterator it = matrix.begin(); it != matrix.end(); it++){vector<int>::iterator fit = lower_bound(it->begin(), it->end(), target);if (fit != it->end() && *fit == target)return true;}return false;}
};

六.题目总结

卧室撒币

http://www.lryc.cn/news/317511.html

相关文章:

  • three.js 鼠标左右拖动改变玩家视角
  • Pycharm jupyter server process exited with code 1
  • ubuntu 20.04 Python pip 配置 pip.conf
  • GPT-4.5 Turbo意外曝光,最快明天发布?OpenAI终于要放大招了!
  • Ubuntu 中 desktop-amd64 和 live-server-amd64 的区别
  • 第10集《天台教观纲宗》
  • 每日学习笔记:C++ STL 的forward_list
  • 【Java,Redis】Redis 数据库存取字符串数据以及类数据
  • OpenCV 图像重映射函数remap()实例详解
  • Python基础课堂最后一课23——正则对象
  • 【算法训练营】凸包,图(Python实现)
  • webpack5零基础入门-6webpack处理图片资源
  • 计算机基础知识QA
  • 微信小程序一次性订阅requestSubscribeMessage授权和操作详解
  • ARM 汇编指令:(三)运算处理指令
  • 【C++庖丁解牛】STL简介 | string容器初次见面
  • 记OnlyOffice的两个大坑
  • 分享几个Google Chrome谷歌浏览器历史版本下载网站
  • 备考2025年AMC8竞赛:吃透2000-2024年600道真题(免费赠送真题)
  • 考研复试C语言篇
  • Docker架构深度解析:守护进程、客户端与存储驱动的协同作战(下)
  • 【强化学习笔记一】初识强化学习(定义、应用、分类、性能指标、小车上山案例及代码)
  • 安卓面试准备汇总
  • C#+datax实现定时增量同步
  • VUE实现Provide的计算属性
  • Spring Schedule:Spring boot整合Spring Schedule实战讲解定时发送邮件的功能
  • Midjourney绘图欣赏系列(十)
  • 【C语言】人生重开模拟器
  • 船舶AIS监控网络-船位信息查询:实时查询船舶动态,服务于船舶安全航行管理、港口调度计划、物流、船代、货代。【AIS动态信息编写船舶轨迹】
  • Axios 中的文件上传(Upload File)方法