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

住房与建设注册中心网站深圳做商城网站

住房与建设注册中心网站,深圳做商城网站,上海关键词排名优化价格,购车网站设计题目 1901. 寻找峰值 II 一个 2D 网格中的 峰值 是指那些 严格大于 其相邻格子(上、下、左、右)的元给你一个 从 0 开始编号 的 m x n 矩阵 mat ,其中任意两个相邻格子的值都 不相同 。找出 任意一个 峰值 mat[i][j] 并 返回其位置 [i,j] 。你可以假设整个矩阵周边…

题目

  • 1901. 寻找峰值 II
  • 一个 2D 网格中的 峰值 是指那些 严格大于 其相邻格子(上、下、左、右)的元
  • 给你一个 从 0 开始编号 的 m x n 矩阵 mat ,其中任意两个相邻格子的值都 不相同 。找出 任意一个 峰值 mat[i][j] 并 返回其位置 [i,j] 。
  • 你可以假设整个矩阵周边环绕着一圈值为 -1 的格子。
  • 要求必须写出时间复杂度为 O(m log(n)) 或 O(n log(m)) 的算法
  • m == mat.length
  • n == mat[i].length
  • 1 <= m, n <= 500
  • 1 <= mat[i][j] <= 10 ^ 5
  • 任意两个相邻元素均不相等.

解法

Java + 列最大值 + 二分

第 1 步:

  • 类似:Leetcode 162. 寻找峰值(Java + 二分)
  • 在行内找严格大于左右的元素,再找每列的最大值(一定是大于上下)
  • 一定需要找该列的最大值,如果这也二分找极大值(仅严格大于左右),那么可能找到非该列最大值从而导致 左/右 列误判

第 2 步:

  • 具体做法:
    • 先找中间=mid 列,找到俩最大值 mat[maxRow][mid] ,元素一定严格大于上下的元素
    • 如果 mat[maxRow][mid] 严格大于左右的元素,则直接返回,否则下一步
    • 如果 mat[maxRow][mid] > mat[maxRow][mid+1] 则 maxRow 左边列一定存在,否则 maxRow 右边列一定存在
  • 时间复杂度:O(m*logn),空间复杂度:O(1)

代码

/*** Java + 列最大值 + 二分:** 第 1 步:* 类似:162. 寻找峰值 FindPeakElement,在行内找严格大于左右的元素,再找每列的最大值(一定是大于上下)* 一定需要找该列的最大值,如果这也二分找极大值(仅严格大于左右),那么可能找到非该列最大值从而导致 左/右 列误判** 第 2 步:* 具体做法:*     * 先找中间=mid 列,找到俩最大值 mat[maxRow][mid] ,元素一定严格大于上下的元素*     * 如果 mat[maxRow][mid] 严格大于左右的元素,则直接返回,否则下一步*     * 如果 mat[maxRow][mid] > mat[maxRow][mid+1] 则 maxRow 左边列一定存在,否则 maxRow 右边列一定存在* 时间复杂度:O(m*logn),空间复杂度:O(1)***/public int[] findPeakGrid(int[][] mat) {int leftCol = 0;int rightCol = mat[0].length - 1;int resCol = 0;while (leftCol <= rightCol) {int midCol = ((rightCol - leftCol) >> 1) + leftCol;int maxRow = getMaxRow(mat, midCol);if ((midCol == 0 || mat[maxRow][midCol] > mat[maxRow][midCol - 1])&& (midCol == mat[0].length - 1 || mat[maxRow][midCol] > mat[maxRow][midCol + 1])) {resCol = midCol;break;}if (midCol == mat[0].length - 1 || mat[maxRow][midCol] > mat[maxRow][midCol + 1]) {rightCol = midCol - 1;} else {leftCol = midCol + 1;}}return new int[]{getMaxRow(mat, resCol), resCol};}private int getMaxRow(int[][] mat, int resCol) {int maxRow = 0;for (int i = 0; i < mat.length; i++) {if (mat[maxRow][resCol] < mat[i][resCol]) {maxRow = i;}}return maxRow;}
http://www.hyszgw.com/news/71586.html

相关文章:

  • 门户 网站 asp阿里巴巴官网首页
  • 门户网站建设 总结做好网站建设的重要性
  • 西安网站制作定制网站数据怎么备份
  • 个体做敦煌网站怎么样wordpress优酷插件
  • 北京高端网站建设优势wordpress 发表文章插件
  • 展示型型网站建设电影网站制作
  • 网站后台管理密码忘记泗县住房和城乡建设局网站
  • 池州网站建设哪家好单位做网站需要准备什么
  • 公司概况介绍怎么写沈阳网站优化推广方案
  • 网站里的地图定位怎么做的lovestory wordpress
  • 可以做哪些有趣的网站网站开发知识体系
  • 做美团网这种网站赚钱吗网页制作的代码
  • 大学生旅游网站策划书外国的html 素材网站
  • 鹰潭北京网站建设优秀网站网页设计分析
  • 锡山建设局网站宣传网页设计作业成品
  • 网站建设 上在线网页生成器
  • 南京网站建设知识全屋整装120平米的多少钱
  • 网站开发职业生涯规划书设计师网页设计作品
  • 青浦郑州阳网站建设邯郸商标vi设计策划公司
  • 昆明云南微网站淘掌门官方网站
  • 唐河网站建设wordpress 主题域名授权
  • 家装公司建设网站网站在广告法之前做的
  • 网站下载免费新版网页教程在线
  • 网站开发项目说明书南京做公司网站的公司
  • 做网站管理怎么赚钱h5制作小程序有哪些
  • 90设计网站终身会员全球做网站最好
  • 集团网站建设哪家更好南通高端网站建设开发
  • 华为做网站吗短视频
  • 煎蛋网站用什么做的单页企业网站模板
  • jsp网站怎么做广州黄浦区建设局网站