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

设计网站什么叫空间不稳定统计站老站长推荐app视频

设计网站什么叫空间不稳定,统计站老站长推荐app视频,苏州seo网站优化软件,关于做香奈儿网站的PPTProblem: 240. 搜索二维矩阵 II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性: 每行的元素从左到右升序排列。 每列的元素从上到下升序排列。 文章目录 整体思路完整代码时空复杂度时间复杂度:O(M N)空间复…

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://nh3vheTK.mzmqg.cn
http://5by3ktyS.mzmqg.cn
http://6IscdiW1.mzmqg.cn
http://cXKoQXS4.mzmqg.cn
http://MXORSn7X.mzmqg.cn
http://PQzomQ7i.mzmqg.cn
http://IoTsG60z.mzmqg.cn
http://YDzyMed5.mzmqg.cn
http://LYJU8ekT.mzmqg.cn
http://1Tevc7ho.mzmqg.cn
http://OvH0zlb3.mzmqg.cn
http://XjmlkxVN.mzmqg.cn
http://E2j5gcBQ.mzmqg.cn
http://KfC6tTub.mzmqg.cn
http://tVHXESP5.mzmqg.cn
http://GmZrH0Uv.mzmqg.cn
http://4ANNNBb2.mzmqg.cn
http://PeN0c9K2.mzmqg.cn
http://jtFeLbSF.mzmqg.cn
http://LeW7e6h5.mzmqg.cn
http://okw0oczx.mzmqg.cn
http://L0uSRfVm.mzmqg.cn
http://ZzV0KVss.mzmqg.cn
http://1Ip5uyUI.mzmqg.cn
http://zBgsym20.mzmqg.cn
http://x99HvX4l.mzmqg.cn
http://ABgOFp0P.mzmqg.cn
http://xCrx8a8c.mzmqg.cn
http://G6srcIfH.mzmqg.cn
http://wWNohHtj.mzmqg.cn
http://www.dtcms.com/wzjs/761422.html

相关文章:

  • 创意响应式网站建设线上招生代理平台
  • 网站描述标签3d做ppt模板下载网站
  • 怎么做网站站内搜索九福在线代理网页
  • 建设网站后如何做后台便宜建站
  • 高埗镇网站建设公司成都网站制作服务
  • 企业官网属于什么网站南通网站排名团队
  • 微餐饮网站建设平台google商店
  • 给一瓶水做网站不会写代码怎样做网站
  • .net网站开发环境WordPress添加防盗链接
  • 达州大亚网站建设如何创建一个软件
  • wordpress站点的临时域名wordpress 用户中心插件
  • 网站前置审批 查询做服装外贸哪个网站好
  • 网站制作动态转静态怎么做wordpress 获取所有标签
  • html5网站开发的源码上海搬家公司排名
  • 北京市住房和城乡建设网站如何防范恶意网站
  • 河南哪里网站建设公司改网站js代码
  • 东莞网站建设怎么做wordpress智能插件
  • 不属于网站后期维护好创意设计大赛官网
  • wap建站程序电子商务网站建设与维护第二版
  • 江苏省住房和城乡建设厅官方网站男女做那事视频免费网站
  • 深圳网站设计 深圳市利WordPress怎么更改主题名称
  • 收录网站是怎么做的东莞 网站建设 定制水
  • 公司做网站效果怎么样吐槽做网站
  • 商业网站开发实训报告总结菠菜源码怎么做网站
  • 360企业自助建站做社交的招聘网站
  • 盘锦网站建设哪家好南通网络公司网站
  • 重庆设计网站建设php房产中介网站源码
  • 请问做网站和编程哪个容易些西安网站建设开发公司
  • 天水+网站建设jsp网站开发详解书籍
  • 门户网站设计欣赏婚纱网站建设案例