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

相关推荐
自然语17 小时前
人工智能之数字生命-特征类升级20260106
人工智能·算法
菜鸟233号17 小时前
力扣343 整数拆分 java实现
java·数据结构·算法·leetcode
赫凯17 小时前
【强化学习】第五章 时序差分算法
算法
leiming617 小时前
c++ find_if 算法
开发语言·c++·算法
yuanmenghao17 小时前
自动驾驶中间件iceoryx - 内存与 Chunk 管理(三)
数据结构·c++·算法·链表·中间件·自动驾驶
_OP_CHEN17 小时前
【算法基础篇】(四十三)数论之费马小定理深度解析:从同余性质到乘法逆元
c++·算法·蓝桥杯·数论·acm/icpc
水月wwww17 小时前
【算法设计】分支限界法
算法·分支限界法
茶猫_17 小时前
C++学习记录-旧题新做-链表求和
数据结构·c++·学习·算法·leetcode·链表
龘龍龙17 小时前
Python基础学习(十一)
python·学习·mysql
yuniko-n17 小时前
【牛客面试 TOP 101】链表篇(一)
数据结构·算法·链表·面试·职场和发展