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

LeetCode 240 搜索二维矩阵 II

题目:

https://leetcode.cn/problems/search-a-2d-matrix-ii/description/?envType=study-plan-v2&envId=selected-coding-interview

问题描述

LeetCode 240题要求在一个二维矩阵中搜索目标值。该矩阵具有以下特性:

  • 每行元素从左到右升序排列。
  • 每列元素从上到下升序排列。

例如:

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(矩阵中存在目标值5)

解题思路:Z字形搜索法

该矩阵的特殊性质(每行每列均有序)允许我们从矩阵的右上角(或左下角)开始搜索,将时间复杂度优化到 O(m+n)(m和n分别为矩阵的行数和列数)。具体步骤如下:

  1. 选择起始点:从矩阵的右上角(即第一行的最后一列,坐标为(0, n-1))开始。
  2. 比较目标值
    • 若当前元素等于目标值,返回true
    • 若当前元素大于目标值,向左移动一列(因为当前列下方的所有元素都更大,不可能包含目标值)。
    • 若当前元素小于目标值,向下移动一行(因为当前行左侧的所有元素都更小,不可能包含目标值)。
  3. 重复步骤2:直到越界(行索引超出m或列索引小于0),此时返回false

代码实现

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {if (matrix.empty() || matrix[0].empty()) return false;int m = matrix.size();    // 行数int n = matrix[0].size(); // 列数int row = 0, col = n - 1; // 从右上角开始while (row < m && col >= 0) {if (matrix[row][col] == target) {return true; // 找到目标值} else if (matrix[row][col] > target) {col--; // 当前元素大于目标值,向左移动} else {row++; // 当前元素小于目标值,向下移动}}return false; // 越界,未找到目标值}
};

代码解释

  1. 初始化

    • row = 0:从第一行开始。
    • col = n - 1:从最后一列开始(右上角)。
  2. 循环搜索

    • 相等条件:若当前元素等于目标值,直接返回true
    • 大于条件:若当前元素大于目标值,说明目标值只能在当前列的左侧,因此col--
    • 小于条件:若当前元素小于目标值,说明目标值只能在当前行的下方,因此row++
  3. 终止条件

    • row超出矩阵行数或col小于0,说明搜索区域已越界,返回false

复杂度分析

  • 时间复杂度:O(m+n)
    每次迭代要么行增加1,要么列减少1,最多需要遍历m行+n列。

  • 空间复杂度:O(1)
    只需要常数级的额外空间。

为什么选择右上角?

右上角的元素是该行的最大值、该列的最小值。这一特性使得:

  • 若当前元素大于目标值,可以排除当前列的所有元素(下方元素更大)。
  • 若当前元素小于目标值,可以排除当前行的所有元素(左侧元素更小)。

同理,从左下角(最后一行的第一列)开始搜索也可以达到相同效果,但从左上角或右下角开始无法有效缩小搜索区域。

示例演示

假设搜索target = 5

[1,   4,  7, 11, 15]  ← 从右上角开始(值=15,大于5,向左移动)
[2,   5,  8, 12, 19]
[3,   6,  9, 16, 22]
[10, 13, 14, 17, 24]
[18, 21, 23, 26, 30][1,   4,  7, 11, 15]
[2,   5,  8, 12, 19]  ← 移动到11(仍大于5,继续向左)
[3,   6,  9, 16, 22]
[10, 13, 14, 17, 24]
[18, 21, 23, 26, 30][1,   4,  7, 11, 15]
[2,   5,  8, 12, 19]  ← 移动到7(仍大于5,继续向左)
[3,   6,  9, 16, 22]
[10, 13, 14, 17, 24]
[18, 21, 23, 26, 30][1,   4,  7, 11, 15]
[2,   5,  8, 12, 19]  ← 移动到4(小于5,向下移动)
[3,   6,  9, 16, 22]
[10, 13, 14, 17, 24]
[18, 21, 23, 26, 30][1,   4,  7, 11, 15]
[2,   5,  8, 12, 19]  ← 移动到5(等于目标值,返回true)
[3,   6,  9, 16, 22]
[10, 13, 14, 17, 24]
[18, 21, 23, 26, 30]

这种方法通过逐步缩小搜索区域,高效地找到目标值或确定其不存在。

相关文章:

  • 向量数据库ChromaDB的使用
  • mongledb数据库应用
  • 【VBA】使用脚本把doc/docx转换为pdf格式
  • 风中低语:Linux 信号处理的艺术与实践
  • 亚远景-ASPICE评估标准解析:汽车软件开发的过程能力模型
  • 金融科技的数字底座
  • 从离散控制到集成管理:Modbus TCP转CANopen网关重构烟丝膨胀生产线
  • 智能守护者:新能源汽车充电桩安全识别技术的创新实践
  • CentOS下的分布式内存计算Spark环境部署
  • 破局与重构:人工智能深度赋能基础教育变革研究
  • QML问题记录
  • v-bind 与 v-model 的区别与联系详解
  • 【Docke基础】Docker简介与快速入门:从概念到核心优势
  • ArkUI-X跨平台Bridge最佳实践
  • Nuclei PoC 编写详解:从入门到实践
  • 【完整源码】白泽题库系统:基于PyQt5的智能刷题与考试平台开发全解析
  • 【threejs】每天一个小案例讲解:常见几何体
  • FastAPI 教程:从入门到实践
  • 主键(PRIMARY KEY)与唯一键(UNIQUE KEY)的区别详解
  • React Native 导航系统实战(React Navigation)
  • 杭州开发app/百度seo排名360
  • wordpress主题 手机/seo技术培训沈阳
  • vs做网站如何放背景图/郑州网络推广平台有哪些
  • 溧阳网站优化/2022搜索引擎
  • 做网站的公司北京有哪些/广州今日新闻最新消息
  • 海拉尔做网站/seo人员的职责