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

相关推荐
木斯佳几秒前
前端八股文面经大全:腾讯PCG暑期前端一面(2026-04-01)·面经深度解析
前端·算法·面经·计算机原理
Q741_1472 分钟前
每日一题 力扣 3661. 可以被机器人摧毁的最大墙壁数目 双指针 动态规划 C++ 题解
c++·算法·leetcode·机器人·动态规划
努力学习的明4 分钟前
JVM 学习路线与实战指南:内存管理、GC 机制及问题诊断
jvm·学习
alphaTao7 分钟前
LeetCode 每日一题 2026/3/30-2026/4/5
算法·leetcode·职场和发展
狮驼岭的小钻风10 分钟前
python系统学习
学习
一定要AK7 小时前
刷题时的学习笔记
c++·笔记·学习
xxxibolva8 小时前
SQL 学习
数据库·sql·学习
圣保罗的大教堂9 小时前
leetcode 3418. 机器人可以获得的最大金币数 中等
leetcode
workflower10 小时前
用硬件换时间”与“用算法降成本”之间的博弈
人工智能·算法·安全·集成测试·无人机·ai编程