本文主要是介绍Python | Leetcode Python题解之第162题寻找峰值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题目:
题解:
class Solution:def findPeakElement(self, nums: List[int]) -> int:n = len(nums)# 辅助函数,输入下标 i,返回 nums[i] 的值# 方便处理 nums[-1] 以及 nums[n] 的边界情况def get(i: int) -> int:if i == -1 or i == n:return float('-inf')return nums[i]left, right, ans = 0, n - 1, -1while left <= right:mid = (left + right) // 2if get(mid - 1) < get(mid) > get(mid + 1):ans = midbreakif get(mid) < get(mid + 1):left = mid + 1else:right = mid - 1return ans
这篇关于Python | Leetcode Python题解之第162题寻找峰值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!