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

软件开发专业就业前景如何网站seo优化网站

软件开发专业就业前景如何,网站seo优化网站,广告设计的工作内容,软件开发培训哪里好74. 搜索二维矩阵 - 力扣(LeetCode) 目录 74. 搜索二维矩阵 - 力扣(LeetCode) 1.题目解析 2.示例 3.解题思路 方法一:从右上角进行查找 方法二:二分查找 1. 将二维矩阵视为一维数组 2. 计算中间索…

74. 搜索二维矩阵 - 力扣(LeetCode)

目录

74. 搜索二维矩阵 - 力扣(LeetCode)

1.题目解析

2.示例

3.解题思路

方法一:从右上角进行查找

方法二:二分查找 

1. 将二维矩阵视为一维数组

2. 计算中间索引 mid

3. 将一维索引转换为二维坐标

4. 获取矩阵中的值

5.为什么这样转换有效?

关键点

4.代码实现

方法一:线性查找

方法二:二分查找


1.题目解析

给你一个满足下述两条属性的 m x n 整数矩阵:

  • 每行中的整数从左到右按非严格递增顺序排列。
  • 每行的第一个整数大于前一行的最后一个整数。

给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 

2.示例

示例 1:

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true

示例 2:

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
输出:false

3.解题思路

方法一:从右上角进行查找

为什么这个方法有效?

  1. 利用有序性

    • 每行从左到右递增

    • 每列从上到下递增

  2. 搜索策略

    • 从右上角开始

    • 比目标大就左移(排除当前列)

    • 比目标小就下移(排除当前行)

  3. 正确性保证

    • 不会错过任何可能的位置

    • 时间复杂度O(m+n)

方法二:二分查找 

1. 将二维矩阵视为一维数组

我们假设将整个二维矩阵按行展开成一个一维数组。例如:

矩阵:
[[1, 3, 5],[7, 9, 11],[13,15,17]
]
展开为:
[1, 3, 5, 7, 9, 11, 13, 15, 17]
2. 计算中间索引 mid

在一维数组中进行二分查找时:

int mid = left + (right - left)/2;

这里 mid 是虚拟一维数组的中间索引。

3. 将一维索引转换为二维坐标

通过以下方式将一维索引 mid 转换为二维坐标:

int row = mid / n;  // 计算行索引
int col = mid % n;  // 计算列索引

其中 n 是矩阵的列数。

4. 获取矩阵中的值

最后通过二维坐标获取矩阵中的值:

int val = matrix[row][col];

具体示例

以矩阵 [[1,3,5,7],[10,11,16,20],[23,30,34,50]] 为例:

  • 矩阵有 3 行 4 列(m=3, n=4)

  • 一维数组索引范围:0 到 11

  • 当 mid = 5 时:

    • row = 5/4 = 1

    • col = 5%4 = 1

    • val = matrix[1][1] = 11

5.为什么这样转换有效?

这种转换方法保证了:

  1. 每个一维索引唯一对应一个二维位置

  2. 保持了矩阵元素的行优先顺序

  3. 可以正确反映矩阵的有序性(如果矩阵是完全有序的)

关键点

  • / 用于计算行索引(整数除法)

  • % 用于计算列索引(取模运算)

  • 这种转换方法的前提是矩阵是按行存储的

这样得到的 val 就是我们在虚拟一维数组中二分查找时当前中间位置的值。

4.代码实现

方法一:线性查找

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {if(matrix.empty() || matrix[0].empty()) return false;int m = matrix.size(), n = matrix[0].size();int row = 0, col = n - 1;while(row < m && col >= 0){if(matrix[row][col] == target)return true;else if(matrix[row][col] > target)col--;elserow++;}return false;}
};

方法二:二分查找

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {if(matrix.empty() || matrix[0].empty()) return false;int m = matrix.size(), n = matrix[0].size();int left = 0, right = m*n - 1;while(left <= right){int mid = (right - left)/2 + left;int val = matrix[mid/n][mid%n];//mid / n是计算行索引//mid % n是计算列索引if(val == target)return true;else if(val < target)left = mid + 1;elseright = mid - 1;}return false;}
};

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

相关文章:

  • php网站开发工程师职责网络游戏推广员的真实经历
  • 网站上做独立博客重庆今天刚刚发生的重大新闻
  • 做关于什么样的网站好湖南网络推广公司大全
  • 浅谈幼儿园网站的建设与管理上海seo外包公司
  • 怎么给企业做网站软文有哪些
  • 做设计一般在那个网站找图关键词排名软件官网
  • 网站开发涉及到缓存吗seo是哪个英文的简写
  • 温州做真皮女鞋的网站有哪些网站安全检测平台
  • python 做爬虫网站百度网盘app下载
  • 网站被墙 做301跳转代运营公司怎么找客户
  • 品牌网站建设信息百度app内打开
  • html5网站开发框架互联网广告代理
  • 内部券网站怎么做公司推广渠道
  • 虚拟主机网站建设国外网站seo
  • 广西网站建设设计seo网络推广课程
  • 免费手机网站网站内链优化
  • 建设小说网站用什么软件下载高报师培训机构排名
  • 珠海手机微信网站建设小程序开发seo的基本步骤顺序正确的是
  • 公司注册资金50万和100万的区别搜索引擎优化教材答案
  • 南宁做网站哪家好互联网营销推广怎么做
  • 论坛模板网站建设seo渠道
  • 需要什么?搜索引擎优化怎么做的
  • wordpress批量删掉文章内的文字seo官网优化怎么做
  • 品牌建设经费投入占销售比重百度seo关键词排名查询工具
  • 网站企业业务员怎么做我也要投放广告
  • 平面设计一般有哪些软件seo网络推广培训班
  • 产品宣传型企业网站怎么建设网站建设的公司
  • 深圳平面设计公司排行百度seo优化怎么做
  • 网站底部的备案信息修改深圳网络推广案例
  • 程序员做电商网站的公司好吗浙江百度推广开户