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

二分查找篇——搜索二维矩阵【LeetCode】遍历法

 74. 搜索二维矩阵

双层循环遍历法

一、算法逻辑(逐步通顺讲解每一步思路)

该算法的目标是判断一个给定的目标值 target 是否存在于二维矩阵 matrix 中。

题目给定的矩阵有如下两个特性:

  1. 每行元素从左到右升序排列;

  2. 每行的第一个整数大于前一行的最后一个整数(整个矩阵可以视作一个升序的「一维数组」)。

然而,这段代码 没有利用上述性质,而是采取了最简单直接的方式:

✅ 1️⃣ 获取矩阵维度

M = len(matrix):总行数;
N = len(matrix[0]):每行列数。

✅ 2️⃣ 遍历整个矩阵

使用两个嵌套循环,逐个元素遍历二维数组中的每一项:

  • 外层循环遍历每一行;

  • 内层循环遍历每一列。

✅ 3️⃣ 逐个比对元素值

如果当前元素 matrix[i][j] 等于 target,直接返回 True;否则继续查找。

✅ 4️⃣ 未找到则返回 False

所有元素遍历完后未找到目标值,返回 False


二、核心点总结

该算法核心非常简单直接:

  • 暴力穷举法:遍历整个二维数组逐个比对元素;

  • 未利用矩阵的有序特性,没有进行任何剪枝或优化;

  • ✅ 实现简单,容易理解;

  • ❌ 对于大数据量输入效率较低。

换句话说,这是最基础的解法(Baseline),适合初学者理解,但在面试或实际场景中不推荐使用

class Solution:def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:M, N = len(matrix), len(matrix[0])for i in range(M):for j in range(N):if matrix[i][j] == target:return Truereturn False

三、时间复杂度分析

共 M 行,每行 N 个元素:

✅ 时间复杂度为 O(M × N)


四、空间复杂度分析

该算法仅使用了常数级别的辅助变量(i, j, M, N),不依赖任何额外数据结构或递归栈:

✅ 空间复杂度为 O(1)


✅ 总结一句话

这是一种最朴素的暴力搜索解法,时间复杂度为 O(M×N),空间复杂度 O(1),实现简单但未利用矩阵的有序性质,适合新手理解,不适合实际使用或面试场景,可进一步优化为「逐行二分查找」或「二维 -> 一维映射 + 二分」的高效解法。

http://www.xdnf.cn/news/1088353.html

相关文章:

  • 使用策略模式 + 自动注册机制来构建旅游点评系统的搜索模块
  • [2-02-02].第03节:环境搭建 - Win10搭建ES集群环境
  • Web后端开发-Mybatis
  • AI趋势与提示词工程
  • 13届蓝桥杯省赛程序设计试题
  • 刷题(一)
  • 【机器学习笔记 Ⅲ】5 强化学习
  • ubuntu24.04(vmware workstation 17.6pro)无法安装vmtools的问题解决
  • 东南亚主播解决方案|东南亚 TikTok 直播专线:纯净住宅 IP 、直播不卡顿
  • menuconfig软件
  • 前后端分离(java) 和 Nginx在服务器上的完整部署方案(redis、minio)
  • Go语言网络游戏服务器模块化编程
  • 国产飞腾主板,赋能网络安全防御硬手段
  • 【Android】组件及布局介绍
  • 微算法科技(NASDAQ MLGO)研究非标准量子预言机,拓展量子计算边界
  • 【WEB】Polar靶场 16-20题 详细笔记
  • navicat导出数据库的表结构
  • 数据库版本自动管理
  • 订单初版—分布式订单系统的简要设计文档
  • Centos和麒麟系统如何每天晚上2点10分定时备份达梦数据库
  • JAVAEE 代理
  • 3D 演示动画在汽车培训与教育领域中的应用
  • Modbus TCP转Profinet网关实现视觉相机与西门子PLC配置实例研究
  • Anolis OS 23 架构支持家族新成员:Anolis OS 23.3 版本及 RISC-V 预览版发布
  • 面试题--系统如何处理异常
  • SpringAI学习笔记-MCP服务器简单示例
  • 【UE5】虚幻引擎小百科
  • 后台设计指南:系统架构、交互规范与工具实战全流程解析
  • (C++)list列表相关基础用法(C++教程)(STL库基础教程)
  • Android T startingwindow使用总结