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

相关推荐
wdfk_prog3 分钟前
[Linux]学习笔记系列 -- [fs]file
linux·笔记·学习
其美杰布-富贵-李13 分钟前
Java (Spring Boot) 反射完整学习笔记
java·spring boot·学习
0x7F7F7F7F15 分钟前
算法竞赛数学知识大全
算法
andwhataboutit?16 分钟前
LLAMAINDEX框架
学习
小许好楠23 分钟前
java开发工程师-学习方式
java·开发语言·学习
小帅学编程35 分钟前
JDBC学习
数据库·学习·oracle
业精于勤的牙1 小时前
最长特殊序列(二)
java·开发语言·算法
其美杰布-富贵-李1 小时前
Python 反射完整学习笔记
笔记·python·学习·反射
yong99901 小时前
C#实现OPC客户端与S7-1200 PLC的通信
开发语言·网络·算法·c#
yaoh.wang1 小时前
力扣(LeetCode) 111: 二叉树的最小深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·深度优先