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

LeetCode 74. 搜索二维矩阵:两种高效解题思路

在LeetCode的数组类题目中「搜索二维矩阵」是一道经典的二分查找应用题核心考察对有序结构的利用和二分思想的灵活运用。题目给出的矩阵有两个关键特性每行从左到右非严格递增且每行第一个元素大于前一行最后一个元素。这两个特性决定了我们可以用高效的二分查找替代暴力遍历将时间复杂度从O(mn)优化到O(log(mn))或O(logm logn)。今天就来拆解这道题的两种主流解题方法结合代码逐行解析帮大家理清思路、吃透细节无论是面试还是日常刷题都能轻松应对。题目回顾给定一个m x n的整数矩阵满足每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。给定一个整数target判断target是否在矩阵中存在返回true否则返回false。示例若矩阵为[[1,3,5,7],[10,11,16,20],[23,30,34,60]]target3则返回truetarget13则返回false。思路一将二维矩阵“扁平化”为一维数组最优解观察题目给出的矩阵特性我们会发现一个关键整个矩阵可以看作是一个“有序的一维数组”。因为每行递增且下一行的第一个元素大于上一行最后一个相当于把所有行拼接起来就是一个严格递增的一维数组。基于这个特性我们可以直接对这个“虚拟的一维数组”做二分查找无需额外处理行和列的关系只需要将一维数组的索引与二维矩阵的行、列做映射即可。代码实现TypeScriptfunctionsearchMatrix_1(matrix:number[][],target:number):boolean{// 边界判断矩阵为空或第一行为空直接返回falseif(!matrix||!matrix[0]){returnfalse;}constmmatrix.length;// 矩阵的行数constnmatrix[0].length;// 矩阵的列数letlow0,highm*n-1;// 虚拟一维数组的左右边界索引从0到m*n-1// 二分查找核心逻辑while(lowhigh){letmidMath.floor((highlow)/2);// 中间索引一维数组// 关键将一维索引mid映射到二维矩阵的行和列// 行索引 Math.floor(mid / n)相当于mid除以列数取整// 列索引 mid % n相当于mid除以列数取余letxmatrix[Math.floor(mid/n)][mid%n];if(xtarget){// 目标值在右半部分缩小左边界lowmid1;}elseif(xtarget){// 目标值在左半部分缩小右边界highmid-1;}else{// 找到目标值直接返回truereturntrue;}}// 循环结束仍未找到返回falsereturnfalse;};核心细节解析边界处理首先判断矩阵是否为空matrix为null/undefined或第一行是否为空matrix[0]为空这两种情况直接返回false避免后续索引越界。索引映射这是该思路的核心。假设虚拟一维数组的索引为mid那么对应的二维矩阵行索引是Math.floor(mid / n)因为每一行有n个元素每n个索引对应一行列索引是mid % n取余得到当前行内的位置。时间复杂度O(log(mn))因为二分查找的次数是log2(mn)每次查找仅做一次索引映射和数值比较时间为O(1)。空间复杂度O(1)仅使用了几个变量存储边界和中间值没有额外开辟空间。思路二两次二分查找先找行再找列如果觉得“扁平化”的索引映射不好理解还可以采用更直观的两次二分查找第一步先找到target可能所在的行第二步在该行中查找target是否存在。第一步找行遍历矩阵的行首元素找到“最后一个行首元素 ≤ target”的行因为矩阵每行递增且下一行首元素大于上一行尾元素target如果存在一定在这一行。第二步找列在找到的目标行中用二分查找判断target是否存在。代码实现TypeScriptfunctionsearchMatrix_2(matrix:number[][],target:number):boolean{// 边界判断矩阵为空或第一行为空直接返回falseif(!matrix||!matrix[0]){returnfalse;}constmmatrix.length;constnmatrix[0].length;// 第一步二分查找目标行返回target可能所在的行索引找不到返回-1constsearchRow():number{letlow0,highm-1;lettargetRow-1;// 初始化目标行为-1表示未找到while(lowhigh){constmidMath.floor((highlow)/2);if(matrix[mid][0]target){// 当前行首元素 ≤ target可能是目标行继续向右查找更合适的行lowmid1;targetRowmid;// 更新目标行}elseif(matrix[mid][0]target){// 当前行首元素 target目标行在左半部分highmid-1;}}returntargetRow;}constrowsearchRow();if(row-1){// 没有找到符合条件的行直接返回falsereturnfalse;}// 第二步在目标行中二分查找targetconstsearchCol():boolean{letlow0,highn-1;while(lowhigh){constmidMath.floor((lowhigh)/2);if(matrix[row][mid]target){lowmid1;}elseif(matrix[row][mid]target){highmid-1;}else{returntrue;}}returnfalse;}returnsearchCol();};核心细节解析找行逻辑searchRow函数中我们始终记录“最后一个行首元素 ≤ target”的行因为如果target存在必然在这一行下一行的行首元素大于target不可能在下行。如果循环结束后targetRow仍为-1说明所有行首元素都大于targettarget不存在。找列逻辑searchCol函数就是标准的一维数组二分查找在目标行中遍历列判断target是否存在。时间复杂度O(logm logn)两次二分查找分别消耗O(logm)和O(logn)整体与思路一的O(log(mn))等价因为log(mn) logm logn。空间复杂度O(1)同样没有额外开辟空间仅使用局部变量。两种思路对比与总结思路核心逻辑时间复杂度空间复杂度特点思路一扁平化将矩阵看作一维数组一次二分查找O(log(mn))O(1)代码简洁索引映射是关键稍难理解思路二两次二分先找行再找列两次二分查找O(logm logn)O(1)逻辑直观分步清晰容易理解解题关键总结这道题的核心是利用矩阵的“有序性”——无论是将其扁平化看作一维有序数组还是分两步找行、找列本质都是二分查找思想的应用。解题时需要注意两个关键点边界处理必须先判断矩阵是否为空、行是否为空避免索引越界。索引映射思路一/ 行判断思路二这是两种思路的核心也是容易出错的地方需要熟练掌握。

相关文章:

LeetCode 74. 搜索二维矩阵:两种高效解题思路

在LeetCode的数组类题目中,「搜索二维矩阵」是一道经典的二分查找应用题,核心考察对有序结构的利用和二分思想的灵活运用。题目给出的矩阵有两个关键特性:每行从左到右非严格递增,且每行第一个元素大于前一行最后一个元素。这两个…...

王炸联动!OpenClaw 对接微信 / 企业微信保姆级教程,AI 办公效率翻倍

前言 作为 2026 年爆火的开源 AI 智能体,OpenClaw早已成为打工人的办公效率神器,但想要让 AI 能力彻底融入日常沟通,实现微信 / 企业微信发指令、AI 秒执行的无缝协作,打通与微信生态的连接是关键! 不管是在企业微信收发消息、同步文件,还是在个人微信调用 AI 处理办公…...

112_深度学习的导航仪:PyTorch 优化器(Optimizer)全解析

在经历了前向传播计算 Loss、反向传播计算梯度(Gradient)后,我们来到了最关键的一步:更新参数。优化器就像是一位经验丰富的导航员,它根据梯度指示的方向,决定如何调整模型的权重,使 Loss 降到最…...

基于ATP-EMTP的10kV并联电容器操作过电压仿真研究:合闸、分闸及母线侧对地电容变化时的分析

基于ATP-EMTP的10 kV 并联电容器的合闸、分闸、母线侧对地电容变化时分闸、合闸后快速分闸操作过电压仿真。最近用ATP-EMTP折腾了个10kV并联电容器的操作过电压仿真。这种带容性负载的开关操作最怕的就是过电压,特别是电容器组这种大电流开断的场景,搞不…...

111_神经网络的指路明灯:损失函数与反向传播深度解析

如果说神经网络的架构是它的“身体”,那么损失函数就是它的“感官”,而反向传播则是它的“进化机制”。通过这两者的结合,模型才能知道自己错在哪里,并朝着正确的方向不断修正。1. 损失函数的核心作用损失函数(Loss Fu…...

计算机毕业设计:Python 小说推荐与阅读系统 Django框架 数据分析 可视化 协同过滤推荐算法 图书 大数据 机器学习(建议收藏)✅

1、项目介绍 技术栈 Python语言、Django框架、MySQL数据库、基于用户与基于物品的双重协同过滤推荐算法、HTML 功能模块 个性化推荐模块:融合基于用户与基于物品的双重推荐算法,根据用户阅读行为和小说内容标签精准推送契合喜好的小说 核心阅读模块&…...

计算机毕业设计:Python全栈图书电商与推荐系统 Django框架 可视化 协同过滤推荐算法 机器学习 大数据 大模型(建议收藏)✅

1、项目介绍 技术栈 Python语言、Django框架、Vue.js前端框架、MySQL数据库、基于用户的协同过滤推荐算法、B/S架构 功能模块 首页模块:以卡片形式展示图书封面、名称、作者等信息,支持按书名、作者、出版社搜索及多维度分类筛选 个性化图书推荐模块&…...

洛谷:P1478 陶陶摘苹果(升级版)

题目描述又是一年秋季时,陶陶家的苹果树结了 n 个果子。陶陶又跑去摘苹果,这次他有一个 a 公分的椅子。当他手够不着时,他会站到椅子上再试试。这次与 NOIp2005 普及组第一题不同的是:陶陶之前搬凳子,力气只剩下 s 了。…...

YOLOv8实战:5种IoU损失函数调参指南(附最新代码适配技巧)

YOLOv8实战:5种IoU损失函数调参指南(附最新代码适配技巧) 目标检测模型的性能优化一直是算法工程师关注的核心问题,而IoU(Intersection over Union)损失函数的选择直接影响模型的收敛速度和检测精度。本文将…...

用MATLAB玩转三维曲面:教你用meshgrid和colormap实现科研级可视化效果

MATLAB三维曲面可视化:从基础绘制到期刊级图表优化 科研图表是学术论文的"门面",一张专业的三维曲面图能让数据规律跃然纸上。作为工程与科学计算领域的标准工具,MATLAB提供了强大的三维可视化能力,但要将原始数据转化为…...

从文档切分到智能检索:MaxKb与Dify的高效协同实践

1. 为什么需要文档切分与智能检索? 在日常工作中,我们经常需要处理大量文档,比如产品说明书、技术手册、合同文件等。这些文档往往包含丰富的信息,但直接阅读和查找特定内容却非常耗时。想象一下,你手里有一本500页的技…...

WuliArt Qwen-Image Turbo内容生产:短视频封面+图文推文配图一体化生成方案

WuliArt Qwen-Image Turbo内容生产:短视频封面图文推文配图一体化生成方案 1. 项目概述 WuliArt Qwen-Image Turbo是一款专为个人GPU环境设计的轻量级文本生成图像系统。这个方案基于阿里通义千问的Qwen-Image-2512文生图底座,并深度融合了Wuli-Art专属…...

Ubuntu+Docker环境下Lucky DDNS与雷池WAF反向代理实战:从配置到攻击测试全流程

UbuntuDocker环境下Lucky DDNS与雷池WAF反向代理实战指南 在当今数字化时代,个人和小型企业对网络安全的需求日益增长。本文将详细介绍如何在Ubuntu系统中利用Docker容器技术,搭建Lucky DDNS动态域名解析服务与雷池Web应用防火墙(WAF)的组合方案&#xf…...

解决GitHub访问问题:顺利获取伏羲模型相关开源工具与代码

解决GitHub访问问题:顺利获取伏羲模型相关开源工具与代码 你是不是也遇到过这种情况?看到一篇介绍伏羲模型(Fuxi)的精彩文章,里面提到了一个配套的开源工具库,你兴致勃勃地点击链接,结果浏览器…...

从《我的世界》联机到视频会议:聊聊FullCone NAT如何悄悄影响你的实时应用体验

从《我的世界》联机到视频会议:聊聊FullCone NAT如何悄悄影响你的实时应用体验 周末晚上,你和朋友约好在《我的世界》搭建一个联机服务器,却发现自己无论如何都无法成功创建主机;而同事家的网络却能轻松实现。视频会议时&#xff…...

Chrome扩展程序:一键切换Host的高效开发利器

1. 为什么开发者需要Host切换工具? 每次调试多环境项目时,你是不是也经历过这样的崩溃时刻?上周我测试电商项目时,用户反馈支付页面时好时坏。为了排查问题,我不得不在本地hosts文件里反复修改服务器IP:把a…...

从零构建存算一体C运行时:用237行标准C代码实现动态权重映射+存内激活函数调度(GitHub Star破1.2k开源项目核心模块拆解)

第一章:存算一体C运行时的设计哲学与架构全景存算一体(Processing-in-Memory, PIM)突破了传统冯诺依曼架构的“内存墙”瓶颈,而C运行时作为底层系统软件的关键枢纽,其设计必须直面硬件异构性、数据局部性强化与指令语义…...

工控安全实战:用Wireshark+Python揪出Modbus网络中的恶意节点(附完整代码)

工控安全实战:用WiresharkPython揪出Modbus网络中的恶意节点(附完整代码) 在工业控制系统(ICS)中,Modbus/TCP协议因其简单易用的特性被广泛应用于PLC、传感器等设备间的通信。然而,这种开放性也…...

用数据说话 9个AI论文写作软件测评:全行业通用,助你高效完成毕业论文与科研写作

在学术研究与论文写作日益数字化的今天,AI写作工具已成为科研人员和高校学生的得力助手。然而,面对市场上琳琅满目的产品,如何选择真正适合自己需求的工具成为一大难题。为此,我们基于2026年的实测数据与用户反馈,开展…...

吐血推荐 10个 AI论文工具:全行业通用测评,助你高效完成毕业论文与科研写作

在当前学术研究与论文写作日益依赖AI工具的背景下,高校师生、科研人员以及各类行业从业者对高效、专业、可靠的写作辅助工具需求愈发迫切。然而,市面上的AI论文工具鱼龙混杂,功能参差不齐,如何快速找到真正契合自身需求的产品成为…...

专科生也能用!标杆级的一键生成论文工具 —— 千笔写作工具

你是否曾为论文选题发愁,反复修改却总对表达不满意?是否在深夜面对空白文档无从下笔,又担心查重率过高?论文写作不仅是知识的考验,更是时间与精力的挑战。对于很多学生来说,从构思到成稿,每一步…...

摆脱论文困扰!一键生成论文工具 千笔ai写作 VS 知文AI 适合研究生

论文写作对于研究生来说,是一场持久战,从选题到答辩,每一个环节都可能成为阻碍进展的“拦路虎”。面对繁杂的写作流程和严格的格式要求,许多学生常常陷入焦虑与低效之中。而千笔AI正是为了解决这一系列痛点而生,它以智…...

FLAC3D耦合PFC3D隧道开挖模拟:位移连续性与地表沉降规律

flac3d耦合pfc3d隧道开挖模拟。 位移连续性良好,地表沉降规律合理。隧道施工总让人头大,尤其是遇到软弱围岩的时候。上次帮设计院做地铁暗挖段模拟,传统连续体方法死活算不出颗粒破碎后的应力重分布。灵机一动把FLAC3D和PFC3D这对冤家凑成了C…...

基于RexUniNLU的智能内容审核系统开发

基于RexUniNLU的智能内容审核系统开发 1. 引言 每天,互联网上产生数以亿计的文字、图片和视频内容,如何高效准确地识别其中的违规信息,成为了平台运营者面临的一大挑战。传统的内容审核主要依赖人工审核,不仅成本高昂&#xff0…...

【架构心法】删掉多线程!撕开通信死锁的黑盒,用 C++ 单线程状态机重塑极速 ACK 与重传引擎

摘要:在强电磁干扰的重工业现场,丢包是物理常态。为了解决数据可靠性,初学者往往会构建一套错综复杂的“多线程收发阻塞等待”架构。本文将无情揭露这种设计在 RTOS 中的性能灾难与死锁宿命。我们将带你完成一次惊艳的架构“逆行”&#xff1…...

通义千问2.5-7B保姆级教程:零基础5分钟本地部署,小白也能玩转AI对话

通义千问2.5-7B保姆级教程:零基础5分钟本地部署,小白也能玩转AI对话 你是不是也对那些动辄几十GB、部署复杂的AI大模型望而却步?觉得本地运行一个智能对话助手是件遥不可及的事情?今天,我要告诉你一个好消息&#xff…...

Qwen与MinerU文档处理对比:哪个更适合中小企业自动化办公场景?

Qwen与MinerU文档处理对比:哪个更适合中小企业自动化办公场景? 1. 引言:中小企业文档处理的痛点与需求 每天面对堆积如山的合同、报表、发票和各类文档,是许多中小企业办公人员的真实写照。手动录入数据、整理文件内容、从扫描件…...

嵌入式开发实战:MIPI-DSI与I2C接口在LCD触控屏中的协同工作原理

嵌入式开发实战:MIPI-DSI与I2C接口在LCD触控屏中的协同工作原理 在现代嵌入式系统中,LCD触控屏已成为人机交互的核心组件。要实现流畅的显示效果和精准的触控响应,需要MIPI-DSI显示接口和I2C触控接口的高效协同工作。本文将深入探讨这两种接口…...

深度学习必备技能:5分钟用Python画出ReLU家族函数图像(含PReLU参数调整技巧)

深度学习必备技能:5分钟用Python画出ReLU家族函数图像(含PReLU参数调整技巧) 在深度学习模型构建中,激活函数的选择直接影响着神经网络的训练效果和收敛速度。对于刚入门的开发者来说,理解不同激活函数的数学特性往往需…...

医学图像分割的“降维打击”:手把手教你用FreMIM的前景掩码策略,告别无效背景干扰

医学图像分割的“降维打击”:手把手教你用FreMIM的前景掩码策略,告别无效背景干扰 在医学影像分析领域,数据标注成本高、模型训练效率低一直是困扰开发者的两大痛点。一张典型的CT或MRI图像中,病灶区域可能只占全图的5%不到&#…...