每日一题 162. 寻找峰值(中等,二分搜索)

每日一题 162. 寻找峰值(中等,二分搜索)_第1张图片

二分搜索

  1. 关键在于,如果 mid 不是峰值索引,假设 mid + 1 大于 mid,显然 mid + 1 有可能是峰值索引,同理可知如果 mid + 1 不是,那么 mid + 2 就有可能是,以此类推,由于 num[n] 是负无穷,因此从 mid + 1 到数组末尾之间必定存在峰值索引
  2. 由 1 我们可以得到推论,当一个值不是峰值时,导致它不是峰值的那一边就必定存在峰值,因此二分得解
class Solution:
    def findPeakElement(self, nums: List[int]) -> int:
        l, r = 0, len(nums)
        while l < r:
            m = (l + r) >> 1
            if (m == len(nums) - 1 or nums[m] > nums[m + 1]) and (m == 0 or nums[m] > nums[m - 1]):
                return m
            if m != len(nums) - 1 and nums[m] <= nums[m + 1]:
                l = m
                continue
            r = m
        
        return l

你可能感兴趣的:(用Python刷力扣,深度优先,算法,python,leetcode)