日拱一卒(16)——leetcode学习记录:山脉数组峰值索引

一、题目

给定一个长度为 n 的整数 山脉 数组 arr ,其中的值递增到一个 峰值元素 然后递减。

返回峰值元素的下标。

你必须设计并实现时间复杂度为 O(log(n)) 的解决方案。

二、分析

要求是O(log(n))的时间复杂度,那么应该采用二分法。具体是找到最大的元素的一半,直至找到峰顶元素。这里实现的细节值得推敲,包括终止条件、判断条件的设置。

O(log(n))的时间复杂度的理解,假设k次二分后范围缩小到1,那么n/2^k = 1,可以求解k是log2(n)

三、题解

class Solution:

def peakIndexInMountainArray(self, arr: List[int]) -> int:

left,right = 0,len(arr)-1

while left+1 < right:

mid = (left+right)//2

if arr[mid] < arr[mid+1]:

left = mid

else:

right = mid

return right

相关推荐
AndrewHZ15 小时前
【图像处理基石】图像处理中的边缘检测算法及应用场景
图像处理·算法·计算机视觉·cv·算子·边缘检测
熊文豪15 小时前
【华为OD】区块链文件转储系统
算法·华为od·区块链
塔中妖15 小时前
【华为OD】Linux发行版的数量
linux·算法·华为od
熊文豪15 小时前
【华为OD】阿里巴巴找黄金宝箱
算法·华为od
bestadc15 小时前
LeetCode 几道 Promises 和 Time 的题目
javascript·算法·leetcode
墨染点香15 小时前
LeetCode 刷题【71. 简化路径】
算法·leetcode·职场和发展
知彼解己16 小时前
【算法】四大基础数据结构
数据结构·算法
老一岁16 小时前
希尔排序详解
数据结构·算法·排序算法
lifallen16 小时前
KafkaStreams 计算图节点设计:ProcessorNode、SourceNode、SinkNode
java·数据结构·算法·kafka·apache
qq77982334016 小时前
PMP考试学习计划与知识大纲
学习·产品经理