欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 名人名企 > 日拱一卒(16)——leetcode学习记录:山脉数组峰值索引

日拱一卒(16)——leetcode学习记录:山脉数组峰值索引

2025/4/25 20:21:54 来源:https://blog.csdn.net/m0_72708335/article/details/144460577  浏览:    关键词:日拱一卒(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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词