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

邢台市建设局安全监督管理网站北京seo网站管理

邢台市建设局安全监督管理网站,北京seo网站管理,越南做彩票网站是违法的吗,头像设计💻 [LeetCode Hot100] 搜索二维矩阵 II🔥二分查找 vs 线性搜索,Java实现,图解代码 ✏️本文对应题目链接:搜索二维矩阵 II 📌 题目描述 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 targ…

💻 [LeetCode Hot100] 搜索二维矩阵 II🔥二分查找 vs 线性搜索,Java实现,图解+代码

✏️本文对应题目链接:搜索二维矩阵 II


📌 题目描述

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target。该矩阵具有以下特性:

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

示例:

输入: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 存在于矩阵中。

🧠 解题思路(图文分解)

❗ 核心难点

如何利用矩阵的特性高效搜索目标值?


方法一:线性搜索(黄金思路)✨

关键步骤:

  1. 从右上角开始搜索
    • 如果当前值等于 target,返回 true
    • 如果当前值大于 target,向左移动一列
    • 如果当前值小于 target,向下移动一行
  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 = 5

步骤1:从右上角开始

初始位置:(0,4) → 15 > 5 → 向左移动

步骤2:向左移动

位置:(0,3) → 11 > 5 → 向左移动

步骤3:向左移动

位置:(0,2) → 7 > 5 → 向左移动

步骤4:向左移动

位置:(0,1) → 4 < 5 → 向下移动

步骤5:向下移动

位置:(1,1) → 5 == 5 → 找到目标值

最终结果:

true

🚀 代码实现

class Solution {public boolean searchMatrix(int[][] matrix, int target) {if (matrix == null || matrix.length == 0 || matrix[0].length == 0) {return false;}int row = 0, col = matrix[0].length - 1; // 从右上角开始while (row < matrix.length && col >= 0) {if (matrix[row][col] == target) {return true;} else if (matrix[row][col] > target) {col--; // 向左移动} else {row++; // 向下移动}}return false;}
}

💡 复杂度分析

  • 时间复杂度:O(m + n) → 最坏情况下需要遍历一行和一列
  • 空间复杂度:O(1) → 仅用常数空间

方法二:二分查找(优化思路)

关键思路:对每一行进行二分查找,适合列数较大的情况。

class Solution {public boolean searchMatrix(int[][] matrix, int target) {if (matrix == null || matrix.length == 0 || matrix[0].length == 0) {return false;}for (int[] row : matrix) {if (binarySearch(row, target)) {return true;}}return false;}private boolean binarySearch(int[] row, int target) {int left = 0, right = row.length - 1;while (left <= right) {int mid = left + (right - left) / 2;if (row[mid] == target) {return true;} else if (row[mid] < target) {left = mid + 1;} else {right = mid - 1;}}return false;}
}

🌟 总结要点

线性搜索核心思想:利用矩阵特性从右上角开始搜索
二分查找优化:适合列数较大的矩阵
适用场景:有序矩阵搜索、二维数组查找


http://www.dtcms.com/wzjs/304335.html

相关文章:

  • 做网站的主要作用的搜索引擎优化
  • 视频网站制作费用网站平台推广
  • 网站后台如何修改新闻发布时间荆门刚刚发布的
  • 网站维护怎么做网站友情链接连接
  • 营销类网站设计 要点百度官网下载安装
  • 网站开发维护承担的法律责任搜索指数
  • 辽宁奔之流建设工程有限公司网站房地产营销策略有哪些
  • 旅游网站怎么设计推广软文是什么意思
  • 临沂网站建设电话seo是搜索引擎营销
  • wordpress默认 页面首页关键词排名优化
  • 自己做网站需要服务器国家职业技能培训平台
  • 交易平台网站程序宁波网站制作优化服务公司
  • 开发网站实时监控个人网站开发网
  • 福田附近网站开发公司企业网站优化关键词
  • 做童装批发网站百度seo软件是做什么的
  • 东莞高明网站设计30个免费货源网站
  • 如何做下载网站赚钱短视频推广平台
  • 苏州做商城网站设计网站 推广
  • 用凡科做网站好弄吗关键词林俊杰mp3下载
  • 成都建设网站平台长沙网站关键词推广
  • 广州网站建设 易企建站全国最新的疫情数据
  • 宁波招聘网站开发免费网站推广工具
  • 手机网站程序做搜索引擎优化的企业
  • 网站设计常州百度推广登录网址
  • 网站开发技术实验教程互联网推广怎么找渠道
  • 网站搭建设计是什么公司软文推广
  • 电子商务后悔死了汕头seo不错
  • 网站 使用的字体网络营销常用工具
  • 公益广告 公司网站建设中...bt磁力天堂torrentkitty
  • 在dw上做网站首页导航栏河南靠谱seo电话