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

相关推荐
散峰而望16 小时前
【算法竞赛】堆和 priority_queue
开发语言·数据结构·c++·算法·贪心算法·动态规划·推荐算法
WarPigs16 小时前
UI显示任务目的地标记的方法
算法·ui
蚊子码农16 小时前
算法题解记录-560和为k的子数组
算法
alexwang21116 小时前
B2007 A + B 问题 题解
c++·算法·题解·洛谷
重生之后端学习16 小时前
46. 全排列
数据结构·算法·职场和发展·深度优先·图论
春和景明36016 小时前
复习数据库
学习
wostcdk16 小时前
数论学习1
数据结构·学习·算法
我是中国人哦(⊙o⊙)17 小时前
我的寒假作业
人工智能·算法·机器学习
Zik----17 小时前
Leetcode2 —— 链表两数相加
数据结构·c++·leetcode·链表·蓝桥杯
.格子衫.17 小时前
030动态规划之树形DP——算法备赛
算法·动态规划