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

相关推荐
追随者永远是胜利者13 小时前
(LeetCode-Hot100)169. 多数元素
java·算法·leetcode·go
s砚山s13 小时前
代码随想录刷题——二叉树篇(二十)
算法
The_Uniform_C@t214 小时前
论文浅读(第三期)|摘自《UAV Resilience Against Stealthy Attacks》(第一节)
网络·物联网·学习·网络安全
青衫码上行14 小时前
高频 SQL 50题(基础版)| 查询 + 连接
数据库·sql·学习·mysql
宇木灵14 小时前
C语言基础学习-X0前置
c语言·开发语言·学习
-Rane14 小时前
【C++】vector
开发语言·c++·算法
希望之晨14 小时前
c++ 11 学习 override
开发语言·c++·学习
代码栈上的思考14 小时前
滑动窗口算法实战
算法
学编程的闹钟14 小时前
E语言组件开发全攻略
学习
winfreedoms15 小时前
Puppypi——树莓派5主板学习笔记
笔记·学习