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

相关推荐
王的宝库4 分钟前
【K8s】集群安全机制(二):授权(Authorization)详解与实战
学习·云原生·容器·kubernetes
ReaF_star6 分钟前
K8s Pod调度【学习笔记】
笔记·学习·kubernetes
Yzzz-F8 分钟前
Problem - D - Codeforces
算法
chas_8812 分钟前
macbook air M5 32G本地跑ddtree-mlx效果
算法
programhelp_14 分钟前
WeRide OA 2026 高频真题分享 & 详细备战指南
经验分享·算法·面试·职场和发展
菜菜的顾清寒39 分钟前
Leetcode (18) 力扣100 矩阵置零
算法
董董灿是个攻城狮1 小时前
5分钟搞懂微调的能力退化问题
算法
fengci.1 小时前
ctfshow其他(web408-web432)
android·开发语言·前端·学习·php
sensen_kiss1 小时前
CPT306 Principles of Computer Games Design 电脑游戏设计原理 Pt.6 Gameplay 游戏玩法
学习·游戏
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.19):下标对中的最大距离
算法·leetcode·职场和发展