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

重庆cms建站模板搜索引擎优化的分类

重庆cms建站模板,搜索引擎优化的分类,wordpress app 插件,网站答辩ppt怎么做文章目录 搜索二维矩阵我的思路网上思路 总结 搜索二维矩阵 给你一个满足下述两条属性的 m x n 整数矩阵: ● 每行中的整数从左到右按非严格递增顺序排列。 ● 每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target 在矩阵中&a…

文章目录

    • 搜索二维矩阵
      • 我的思路
      • 网上思路
    • 总结

搜索二维矩阵

给你一个满足下述两条属性的 m x n 整数矩阵:
● 每行中的整数从左到右按非严格递增顺序排列。
● 每行的第一个整数大于前一行的最后一个整数。
给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false

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

我的思路
循环,尝试二分法
网上思路
二分法

我的思路

var searchMatrix = function (matrix, target) {if (matrix.length === 0 || matrix[0].length === 0) {return false;}const rows = matrix.length;const cols = matrix[0].length;for (let i = 0; i < rows; i++) {if (target < matrix[i][0]) {return false;}if (target > matrix[i][cols - 1]) {continue;}for (let j = 0; j < cols; j++) {if (matrix[i][j] === target) {return true;}}}return false;
};

讲解
双重循环,主要是以下边界条件进行判断

  1. 如果 target 小于当前行的第一个元素,直接返回 false
  2. 如果 target 大于当前行的最后一个元素,继续检查下一行。

网上思路

var searchMatrix = function(matrix, target) {const m = matrix.length, n = matrix[0].length;let low = 0, high = m * n - 1;while (low <= high) {const mid = Math.floor((high - low) / 2) + low;const x = matrix[Math.floor(mid / n)][mid % n];if (x < target) {low = mid + 1;} else if (x > target) {high = mid - 1;} else {return true;}}return false;
};

讲解
若将矩阵每一行拼接在上一行的末尾,则会得到一个升序数组,我们可以在该数组上二分找到目标元素。
代码实现时,可以二分升序数组的下标,将其映射到原矩阵的行和列上。

  1. 初始化两个指针 lowhighlow 指向矩阵的 起始位置(0)high 指向矩阵的 结束位置(总元素数 - 1)
  2. low 小于或等于 high 时,继续进行查找。
  3. 计算中间位置 mid。这里使用了 (high - low) / 2 来避免直接相加可能导致的溢出。
  4. 将一维索引 mid 转换为二维索引:
    1. 行索引为 Math.floor(mid / n),表示当前元素在矩阵中的行。
    2. 列索引为 mid % n,表示当前元素在矩阵中的列。
    3. 这样就可以通过 x 获取当前中间位置的元素。
  5. 如果当前元素 x 小于 target,则目标值一定在右半部分,因此将 low 更新为 mid + 1
  6. 如果当前元素 x 等于 target,则找到了目标值,返回 true

总结

很实用,正好我自身有项目在使用二维矩阵,明天我来试试

http://www.yidumall.com/news/106932.html

相关文章:

  • 白银做网站的董事自己建网站怎么建
  • 织梦教育培训网站源码网络营销到底是干嘛的
  • 宁波企业网站建设seo关键字排名优化
  • 自己做企业网站用哪个软件优化方案官网
  • 微网站自己可以做么优化设计四年级上册数学答案
  • 深圳电子商城网站建设外贸网络推广营销
  • wordpress网站如何清理js宁波seo关键词如何优化
  • 个人如何做微商城网站设计seo营销策略
  • php企业网站无限制源码南京网站设计
  • 网络营销网站策划口碑最好的it培训机构
  • 野花香社区在线观看播放seo导航
  • 网站修改备案号个人网站模板
  • 威海网站开发制作广东网站优化公司
  • 太原注册公司在哪个网站申请16种营销模型
  • 注册免费的网站seo包括哪些方面
  • 做网站的作文国际最新新闻热点事件
  • 西宁做网站的公司百度关键词推广怎么做
  • wordpress抓取文章插件杭州优化建筑设计
  • 部门子网站建设方案seo工作内容和薪资
  • 做试客需要去哪些网站山东网站seo推广优化价格
  • 哈尔滨网站建设教程百度企业网盘
  • 济南模板网站制作交友网站有哪些
  • 国内flex做的网站全国培训机构排名前十
  • 虚拟机怎么做网页网站怎样关键词排名优化
  • 做服装搭配直接售卖的网站什么是seo?
  • 马鞍山政府网站谁做的seo关键词排名优化费用
  • 微信表情开放平台官网黄石seo
  • 安徽网站设计定制陕西百度推广的代理商
  • 做门户网站需要什么条件百度一下 你就知道官方
  • 网站做信用认证有必要吗成都网站seo服务