日拱一卒(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

相关推荐
样例过了就是过了3 分钟前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs
2401_898075124 分钟前
分布式系统监控工具
开发语言·c++·算法
程序员夏末11 分钟前
【LeetCode | 第六篇】算法笔记
笔记·算法·leetcode
AnalogElectronic23 分钟前
RP2040学习4,LED点亮,OLED显示,DHT11温湿度传感器数据读取
单片机·嵌入式硬件·学习
adore.96828 分钟前
3.15 复试学习
学习
OKkankan28 分钟前
撕 STL 系列:封装红黑树实现 mymap 和 myset
java·c++·算法
xh didida33 分钟前
数据结构--实现链式结构二叉树
c语言·数据结构·算法
ab15151733 分钟前
3.15二刷基础90、105、106、110
数据结构·c++·算法
C蔡博士34 分钟前
最近点对问题(Closest Pair of Points)
java·python·算法
白太岁36 分钟前
算法:链表:指针变化与环
数据结构·算法·链表