LeetCode 分类刷题:1901. 寻找峰值 II

题目

一个 2D 网格中的 峰值 是指那些 严格大于其相邻格子(上、下、左、右)的元素。

给你一个从 0 开始编号m x n 矩阵 mat ,其中任意两个相邻格子的值都不相同 。找出 任意一个 峰值 mat[i][j]返回其位置 [i,j]

你可以假设整个矩阵周边环绕着一圈值为 -1 的格子。

要求必须写出时间复杂度为 O(m log(n))O(n log(m)) 的算法

解析

利用行最大值判断峰顶位置

我们可以二分包含峰顶的行号 i:

  • 如果 mat[i] 的最大值比它下面的相邻数字小,则存在一个峰顶,其行号大于 i。缩小二分范围,更新二分区间左端点 left。
  • 如果 mat[i] 的最大值比它下面的相邻数字大,则存在一个峰顶,其行号小于或等于 i。缩小二分范围,更新二分区间右端点 right。

对于本题,如果每次二分,都是 mat[i] 的最大值比它下面的相邻数字小,那么最后会判断出峰顶行号大于 m−2,此时可以直接确定最后一行必然包含峰顶

这意味着 m−1 不需要在初始二分范围内 ,初始二分范围为 [0,m−2]。在这个范围中二分,如果每次都更新的是区间左端点 left,那么最后得到的二分结果必然是 m−1。

如果在 [0,m−1] 中二分,还需要额外判断 i+1 是否越界。在 [0,m−2] 中二分可以避免越界判断。

作者:灵茶山艾府

链接:https://leetcode.cn/problems/find-a-peak-element-ii/solutions/2571587/tu-jie-li-yong-xing-zui-da-zhi-pan-duan-r4e0n/

来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

答案

python 复制代码
class Solution:
    def findPeakGrid(self, mat: List[List[int]]) -> List[int]:
        left, right = -1, len(mat) - 1
        while left + 1 < right:
            i = (left + right) // 2
            mx = max(mat[i])
            if mx > mat[i + 1][mat[i].index(mx)]:
                right = i  # 峰顶行号 <= i
            else:
                left = i  # 峰顶行号 > i
        return [right, mat[right].index(max(mat[right]))]

# 作者:灵茶山艾府
# 链接:https://leetcode.cn/problems/find-a-peak-element-ii/solutions/2571587/tu-jie-li-yong-xing-zui-da-zhi-pan-duan-r4e0n/
# 来源:力扣(LeetCode)
# 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

复杂度分析

时间复杂度:O(nlogm),其中 m 和 n 分别为 mat 的行数和列数。需要二分 O(logm) 次,每次二分需要 O(n) 的时间寻找 mat[i] 最大值的下标。

空间复杂度:O(1)。仅用到若干额外变量。

作者:灵茶山艾府

链接:https://leetcode.cn/problems/find-a-peak-element-ii/solutions/2571587/tu-jie-li-yong-xing-zui-da-zhi-pan-duan-r4e0n/

来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关推荐
Hgfdsaqwr8 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
TracyCoder1239 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
开发者小天9 小时前
python中For Loop的用法
java·服务器·python
老百姓懂点AI9 小时前
[RAG实战] 向量数据库选型与优化:智能体来了(西南总部)AI agent指挥官的长短期记忆架构设计
python
u01092727110 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_9418372610 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
六义义11 小时前
java基础十二
java·数据结构·算法
四维碎片11 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs11 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
喵手11 小时前
Python爬虫零基础入门【第九章:实战项目教学·第15节】搜索页采集:关键词队列 + 结果去重 + 反爬友好策略!
爬虫·python·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·搜索页采集·关键词队列