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

福州网站关键词代运营公司哪家好一些

福州网站关键词,代运营公司哪家好一些,桂林旅游网站建设,电影资源下载wordpress搜索二维矩阵 一、题目背景二、题目描述示例 1:示例 2:约束条件: 三、解题思路分析1. **错误思路回顾**2. **Z字形查找算法**算法步骤: 3. **算法优势** 四、代码实现代码说明: 五、测试用例测试用例 1:测试…

搜索二维矩阵

    • 一、题目背景
    • 二、题目描述
      • 示例 1:
      • 示例 2:
      • 约束条件:
    • 三、解题思路分析
      • 1. **错误思路回顾**
      • 2. **Z字形查找算法**
        • 算法步骤:
      • 3. **算法优势**
    • 四、代码实现
      • 代码说明:
    • 五、测试用例
      • 测试用例 1:
      • 测试用例 2:
      • 测试用例 3:
    • 六、总结

一、题目背景

在LeetCode上,有一道经典的二维矩阵搜索问题——“搜索二维矩阵 II”。题目要求在一个具有特定性质的二维矩阵中查找目标值。矩阵的每一行从左到右升序排列,每一列从上到下升序排列。我们需要设计一个高效的算法来判断目标值是否存在于矩阵中。

二、题目描述

给定一个二维矩阵matrix和一个目标值target,矩阵的行数为m,列数为n。矩阵满足以下性质:

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

我们需要判断目标值target是否存在于矩阵中。

示例 1:

输入:

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

示例 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 = 20

输出:false

约束条件:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= m, n <= 300
  • -10^9 <= matrix[i][j] <= 10^9
  • 每一行的所有元素从左到右升序排列
  • 每一列的所有元素从上到下升序排列
  • -10^9 <= target <= 10^9

三、解题思路分析

1. 错误思路回顾

在解题过程中,我们可能会尝试一些直观的思路,但这些方法往往效率低下或存在逻辑错误。例如,从矩阵的左上角开始逐行逐列搜索,或者在矩阵中随机选择一个起点进行搜索。这些方法的时间复杂度较高,无法满足题目对效率的要求。

2. Z字形查找算法

经过分析,我们发现一种高效的搜索方法——Z字形查找。这种方法利用了矩阵的有序性,从矩阵的右上角(或左下角)开始搜索,通过逐步调整搜索范围,快速定位目标值。

算法步骤:
  1. 初始化:从矩阵的右上角开始搜索,设当前坐标为(x, y),其中x = 0y = n - 1
  2. 搜索过程
    • 如果matrix[x][y] == target,说明找到了目标值,返回true
    • 如果matrix[x][y] > target,由于每一列是升序排列的,当前列的所有元素都大于目标值,因此将y减1,即向左移动。
    • 如果matrix[x][y] < target,由于每一行是升序排列的,当前行的所有元素都小于目标值,因此将x加1,即向下移动。
  3. 边界条件:如果搜索过程中超出矩阵的边界(x >= my < 0),说明目标值不存在,返回false

3. 算法优势

Z字形查找算法充分利用了矩阵的有序性,避免了不必要的搜索。其时间复杂度为O(m + n),其中m是矩阵的行数,n是矩阵的列数。相比暴力搜索(时间复杂度为O(m * n)),这种方法效率显著提高。

四、代码实现

以下是基于Z字形查找算法的C语言实现:

bool searchMatrix(int** matrix, int matrixSize, int* matrixColSize, int target) {int m = matrixSize;       // 矩阵的行数int n = *matrixColSize;   // 矩阵的列数int x = 0, y = n - 1;     // 从右上角开始搜索while (x < m && y >= 0) { // 确保搜索范围在矩阵内if (matrix[x][y] == target) { // 找到目标值return true;} else if (matrix[x][y] > target) { // 当前值大于目标值,向左移动y--;} else { // 当前值小于目标值,向下移动x++;}}return false; // 超出矩阵边界,目标值不存在
}

代码说明:

  1. 初始化x为0,y为矩阵的列数减1,即从右上角开始。
  2. 循环条件x < my >= 0,确保搜索范围在矩阵内。
  3. 搜索逻辑
    • 如果当前值等于目标值,直接返回true
    • 如果当前值大于目标值,向左移动(y--)。
    • 如果当前值小于目标值,向下移动(x++)。
  4. 返回结果:如果超出矩阵边界仍未找到目标值,返回false

五、测试用例

测试用例 1:

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

测试用例 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 = 20

输出false

测试用例 3:

matrix = [[1, 2, 3],[4, 5, 6],[7, 8, 9]
]
target = 7

输出true

六、总结

通过Z字形查找算法,我们能够高效地解决“搜索二维矩阵 II”问题。这种方法充分利用了矩阵的有序性,避免了暴力搜索的低效性。在实际应用中,我们还可以根据矩阵的性质选择其他优化策略,例如从左下角开始搜索,逻辑与从右上角类似。
这题本质上就是从右上角往右下角遍历,还是比较容易的。

http://www.tj-hxxt.cn/news/121473.html

相关文章:

  • 网站备案 网站建设方案书需要写吗广州seo成功案例
  • 关于网站设计与建设的论文seo网络营销技巧
  • 大连网站建设介绍制作一个网站步骤
  • 旅游网页设计模板图凡科网站seo
  • 新乡网站建设那家好搜索引擎营销有哪些方式
  • 如何把自己做的网站放到微信上宁波seo在线优化哪家好
  • 南宁企业建站程序香飘飘奶茶
  • cms 导航网站智推教育seo课程
  • 域名访问网站是什么意思seo是什么及作用
  • 碑林区营销型网站建设推广任务接单平台
  • 牡丹江建设工程信息网站深圳竞价排名网络推广
  • 怎样自己做公司网站中国新闻最新消息
  • 网站上传图片教程希爱力副作用太强了
  • 贵阳网站建设培训百度山西授权代理
  • 爱做网站免费版宁波网络营销公司
  • 洛阳 网站建设湖南搜索引擎推广平台
  • java做网站注册怎么弄今天最新新闻国内大事件
  • 永春网站开发东莞网站开发公司
  • 网站建设论文标题视频号最新动作
  • wordpress 获取当前路径企业站seo外包
  • 网站建设考试样题及答案指数基金怎么选
  • 注册公司网站如何注册制作网站的平台
  • 班级网站制作模板关键词挖掘工具爱网
  • 海南医院网站建设新的营销方式有哪些
  • 建设网站dns如何设置谷歌独立站
  • 做淘客网站要备案推广软件
  • 山西网站建设鸣蝉百度推广登录后台登录入口
  • 备案用的网站建设方案书黄桃图片友情链接
  • 外贸线上推广seo网站优化知识
  • html公益网站模板怎么制作网页