【LeetCode 热题 100】240. 搜索二维矩阵 II——排除法

Problem: 240. 搜索二维矩阵 II
编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:
每行的元素从左到右升序排列。
每列的元素从上到下升序排列。

文章目录

  • 整体思路
  • 完整代码
  • 时空复杂度
    • 时间复杂度:O(M + N)
    • 空间复杂度:O(1)

整体思路

这段代码旨在解决一个经典的矩阵搜索问题:搜索二维矩阵 II (Search a 2D Matrix II)。问题要求在一个特殊的 M x N 矩阵中高效地查找一个目标值 target。这个矩阵的特殊之处在于:

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

该算法采用了一种非常巧妙且高效的 “Z”字形(或称为“锯齿形”)查找法。它利用了矩阵的行列双重有序性,以线性的时间复杂度完成搜索。

  1. 选择起点

    • 算法的关键在于选择一个合适的起点。它选择了矩阵的 右上角 (0, n-1) 作为起始搜索点。
    • 为什么是右上角(或左下角):这个位置非常特殊。对于右上角的元素 matrix[i][j]
      • 小于同一行右侧的所有元素(不存在)。
      • 大于同一行左侧的所有元素。
      • 小于同一列下方的所有元素。
      • 大于同一列上方的所有元素(不存在)。
    • 这种特性使得每一次比较都能排除掉一整行或一整列的元素,从而实现高效的搜索。
  2. 搜索路径与排除逻辑

    • 算法使用一个 while 循环来持续搜索,只要指针 (i, j) 还在矩阵范围内(i < m && j >= 0)。
    • 在循环的每一步,将当前指针指向的元素 matrix[i][j]target 进行比较:
      • Case 1: matrix[i][j] == target
        • 找到了目标值,直接返回 true
      • Case 2: matrix[i][j] < target
        • 由于当前元素 matrix[i][j]target 小,并且它已经是当前行 i 中最大的元素(因为我们从最右边开始),所以 target 不可能在当前行的任何位置。
        • 因此,我们可以安全地排除掉整个第 i,并将搜索范围向下移动一行。实现方式是 i++
      • Case 3: matrix[i][j] > target
        • 由于当前元素 matrix[i][j]target 大,并且它已经是当前列 j 中最小的元素(因为我们从最上边开始),所以 target 不可能在当前列的任何位置。
        • 因此,我们可以安全地排除掉整个第 j,并将搜索范围向左移动一列。实现方式是 j--
  3. 终止条件

    • while 循环会一直持续,直到指针移出矩阵边界(i 越过下边界或 j 越过左边界)。
    • 如果循环结束了还没有找到 target,就说明目标值在矩阵中不存在,返回 false

这个算法的路径就像在矩阵中画一条从右上到左下的折线,每一步都剔除一行或一列,因此效率非常高。

完整代码

class Solution {/*** 在一个行列都升序的矩阵中高效地查找一个目标值。* @param matrix 一个 M x N 的整数矩阵,每行从左到右升序,每列从上到下升序。* @param target 要查找的目标值。* @return 如果找到目标值则返回 true,否则返回 false。*/public boolean searchMatrix(int[][] matrix, int target) {// 获取矩阵的行数和列数int m = matrix.length;int n = matrix[0].length;// 步骤 1: 初始化指针,指向矩阵的右上角int i = 0;     // 行指针,从第 0 行开始int j = n - 1; // 列指针,从最后一列开始// 步骤 2: 循环搜索,只要指针还在矩阵范围内while (i < m && j >= 0) {// Case 1: 找到目标值if (matrix[i][j] == target) {return true;}// Case 2: 当前元素小于目标值// 说明 target 不可能在当前行,因为 matrix[i][j] 是当前行最大的// 排除当前行,向下移动if (matrix[i][j] < target) {i++;} else { // Case 3: 当前元素大于目标值// 说明 target 不可能在当前列,因为 matrix[i][j] 是当前列最小的// 排除当前列,向左移动j--;}}// 步骤 3: 如果循环结束仍未找到,说明目标值不存在return false;}
}

时空复杂度

时间复杂度:O(M + N)

  1. 指针移动分析
    • 算法的核心是两个指针 ij 的移动。
    • 指针 i 只会单调递增(向下移动),从 0 最多移动到 m
    • 指针 j 只会单调递减(向左移动),从 n-1 最多移动到 -1
  2. 循环次数
    • while 循环的每一次迭代中,ij 至少有一个会移动。
    • i 最多移动 M 次,j 最多移动 N 次。
    • 因此,循环的总执行次数最多为 M + N 次。

综合分析
算法的时间复杂度与行数和列数的和成线性关系,即 O(M + N)

空间复杂度:O(1)

  1. 主要存储开销:该算法直接在输入的 matrix 数组上进行查找,没有创建任何新的、与输入规模 MN 成比例的数据结构。
  2. 辅助变量:只使用了 m, n, i, j, target 等几个常数数量的变量。

综合分析
算法所需的额外辅助空间是常数级别的。因此,其空间复杂度为 O(1)。这是一个空间效率极高的原地算法。

参考灵神

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/89968.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/89968.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android Input 系列专题【inputflinger事件的读取与分发】

Android输入系统在native中的核心工作就是&#xff0c;从Linux驱动设备节点中读取事件&#xff0c;然后将这个事件进行分发&#xff0c;这两项工作分别交给了InputReader和InputDispatcher来做。 他们的源码都属于native层inputflinger里面的一部分&#xff0c;如下架构&#…

【大模型LLM】GPU计算效率评估指标与优化方法:吞吐率

GPU计算效率评估指标与优化方法&#xff1a;吞吐率 一、核心效率指标二、大模型吞吐率&#xff08;Large Model Throughput&#xff09;三、关键性能瓶颈分析四、实际测量工具五、优化策略总结 一、核心效率指标 吞吐率&#xff08;Throughput&#xff09; 定义&#xff1a;单位…

Nestjs框架: 集成 Prisma

概述 在 NestJS 的官方文档中&#xff0c;有两处对数据库进行了介绍 第一处位于左侧“Techniques&#xff08;技术&#xff09;”部分下的“数据库”板块&#xff0c;中文文档里同样有这个位置。 Database 第二处是下面的“Recipes (秘籍)”板块&#xff0c;这里有多个部分都与…

CppCon 2018 学习:What Do We Mean When We Say Nothing At All?

提供的内容深入探讨了C编程中的一些关键概念&#xff0c;特别是如何编写清晰、易维护的代码&#xff0c;并展示了一些C17的新特性。我将对这些内容做中文的解释和总结。 1. 良好的代码设计原则 什么是“良好的代码”&#xff1f; 能工作&#xff1a;代码实现了预期功能。能在…

C语言中的输入输出函数:构建程序交互的基石

在C语言的世界里&#xff0c;输入输出&#xff08;I/O&#xff09;操作是程序与用户或外部数据源进行交互的基本方式。无论是从键盘接收用户输入&#xff0c;还是将处理结果显示到屏幕上&#xff0c;亦或是读写文件&#xff0c;都离不开C语言提供的输入输出函数。本文将深入探讨…

高速信号眼图

横轴体系时域的抖动大小&#xff1b;纵轴体现电压的噪声。 噪声越大&#xff0c;眼高越小。 抖动越大&#xff0c;眼宽越窄。 眼图的模板是定义好的最大jitter和噪声的模板范围。就是信号的不可触碰区域。信号波形不能够触碰到模板或者进行模板中。也就是眼图中的线轨迹要在眼…

VisualSVN Server 禁止的特殊符号 导致的。具体分析如下:错误提示解读

是由于 文件夹名称中包含了 VisualSVN Server 禁止的特殊符号 导致的。具体分析如下&#xff1a; 错误提示解读 错误信息明确说明&#xff1a; Folder name cannot contain following symbols < > : " / | and start or end by period. 即 文件夹名称不能包含以下…

再见,WebSecurityConfigurerAdapter!你好,SecurityFilterChain

对于许多经验丰富的 Spring开发者来说&#xff0c;WebSecurityConfigurerAdapter 是一个再熟悉不过的名字。在很长一段时间里&#xff0c;它几乎是所有 Spring Security 配置的起点和核心。然而&#xff0c;随着 Spring Boot 3.x 和 Spring Security 6.x 的普及&#xff0c;这个…

web前端面试-- MVC、MVP、MVVM 架构模式对比

MVC、MVP、MVVM 架构模式对比 基本概念 这三种都是用于分离用户界面(UI)与业务逻辑的架构模式&#xff0c;旨在提高代码的可维护性、可测试性和可扩展性。 1. MVC (Model-View-Controller) 核心结构&#xff1a; Model&#xff1a;数据模型和业务逻辑View&#xff1a;用户界面展…

【C#】MVVM知识点汇总-2

在C#中实现MVVM&#xff08;Model-View-ViewModel&#xff09;架构时&#xff0c;可以总结以下几个关键知识点&#xff0c;并通过具体的代码示例来进行说明。 1. 模型 (Model) 模型包含应用程序中的数据和业务逻辑。通常与数据库交互。 public class User { public int Id {…

一文了解PMI、CSPM、软考、、IPMA、PeopleCert和华为项目管理认证

1 引言 常见的项目管理方面的认证有PMI、IPMA、PeopleCert、CSPM、软考和华为项目管理认证6个认证。本篇文章让你一文了解各认证的基本主要内容。 2 核心定位 目前全球范围内最具影响力的六大认证体系各有特色&#xff0c;源于不同的管理哲学和实践背景。六大认证体系的核心…

bean注入的过程中,Property of ‘java.util.ArrayList‘ type cannot be injected by ‘List‘

一、问题 在spring实践bean注入ArrayList属性的时候报错&#xff1a;Property of ‘java.util.ArrayList’ type cannot be injected by ‘List’二、原因分析 在尝试将 Spring 配置中的 注入到一个 ArrayList 类型的属性时出现了类型不匹配问题。核心问题在于&#xff1a;Spr…

自注意力机制原理: 向量矩阵案例进行说明

自注意力机制原理: 向量矩阵案例进行说明 目录 自注意力机制原理: 向量矩阵案例进行说明一个单词和所有单词进行乘法运算,提取特征一、场景设定:翻译句子“我喜欢深度学习”二、向量矩阵构建:以“我”为例计算自注意力三、矩阵视角:批量计算整个序列的自注意力四、向量矩…

D3 面试题100道之(61-80)

这里是D3的面试题,我们从第 61~80题 开始逐条解答。一共100道,陆续发布中。 🟨 面试题(第 61~80 题) 61. D3 中如何绘制饼图? 使用 d3.pie() 生成角度数据,再结合 d3.arc() 创建路径。 示例: const data = [10, 20, 30

flutter更改第三方库pub get的缓存目录;更改.gradle文件夹存放目录

1.在目标目录中新建文件夹flutter_pub_cache 2.在“用户变量“或“系统变量”中点击“新建” 变量名: PUB_CACHE 变量值: D:\flutter_pub_cache 3.打开新的终端运行或者从Android studio 控制台运行&#xff1a;flutter pub cache repair或者flutter pub clean pub读取新的变…

《Redis》哨兵模式

文章目录 为什么要有哨兵模式呢&#xff1f;哨兵自动恢复故障主节点使用docker搭建分布式系统查看哨兵节点工作哨兵选举新的主节点的流程 总结 为什么要有哨兵模式呢&#xff1f; 主从复制的问题 Redis 的主从复制模式可以将主节点的数据改变同步给从节点&#xff0c;这样从节…

零基础保姆级本地化部署文心大模型4.5开源系列

近两年随着大模型的迅猛崛起&#xff0c;吸引了各行各业的广泛关注&#xff0c;更对我们的工作方式与生活产生着显著积极影响。在这样一个技术范式转换的关键节点&#xff0c;百度文心大模型开源事件无疑具有里程碑意义——它不仅为中国自主研发的AI技术底座打开了通向世界的大…

【笔记】PyCharm 2025.2 EAP 创建 Poetry 和 Hatch 环境的踩坑实录与反馈

https://youtrack.jetbrains.com/issue/PY-82407/Incorrect-Python-Version-and-Virtual-Environment-Path-When-Creating-Poetry-and-Hatch-Environments-via-GUI-in-PyCharm-2025.2-EAP 在 Python 开发的道路上&#xff0c;PyCharm 一直是我们信赖的开发利器。然而&#xff0…

ASP.NET Web Pages 安装使用教程

一、ASP.NET Web Pages 简介 ASP.NET Web Pages 是微软推出的一种轻量级 Web 开发框架&#xff0c;适合快速开发动态网站。它使用 Razor 语法&#xff0c;可以将 HTML 与 C# 或 VB.NET 无缝融合&#xff0c;特别适合初学者和小型项目。 二、Web Pages 与 MVC 的区别 特性Web …

基于 ethers.js 的区块链事件处理与钱包管理

币圈工具箱 bqbot.cn 月访问量达90whttps://bqbot.cn/jms.html &#xff08;在线版地址&#xff09; Event事件 检索事件 const { ethers } require("hardhat"); async function SearchEvent() {try {const provider new ethers.JsonRpcProvider("http://1…