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

相关推荐
努力d小白17 分钟前
leetcode230.二叉搜索树中第k小的元素
数据结构·算法
MC何失眠17 分钟前
vulnhub靶场【shenron】之3
网络·学习·web安全·网络安全
SoraLuna26 分钟前
「Mac玩转仓颉内测版52」基础篇14 - 递归函数与尾递归优化
开发语言·算法·macos·华为·cangjie
shinelord明36 分钟前
【再谈设计模式】组合模式~层次构建的多面手
数据结构·算法·设计模式·软件工程
残月只会敲键盘36 分钟前
Python学习通移动端自动化刷课脚本,雷电模拟器近期可能出现的问题,与解决方案
学习
番茄灭世神40 分钟前
Qt学习笔记第61到70讲
笔记·学习
di.D1 小时前
判断闰年---算法
数据结构·算法·c#
羽墨灵丘1 小时前
排序算法(6):快速排序
算法·排序算法
Yolo566Q1 小时前
LEAP模型的能源环境发展、碳排放建模预测及不确定性分析实践应用
人工智能·算法
7yewh1 小时前
LeetCode 力扣 热题 100道(十九)最长连续序列(C++)
c语言·数据结构·c++·算法·leetcode·嵌入式