寻找峰值——二分

峰值元素是指其值严格大于左右相邻值的元素。

给你一个整数数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。

你可以假设 nums[-1] = nums[n] = -∞

你必须实现时间复杂度为 O(log n)的算法来解决此问题。

示例 1:

复制代码
输入:nums = [1,2,3,1]
输出:2
解释:3 是峰值元素,你的函数应该返回其索引 2。
  • 对于所有有效的 i 都有 nums[i] != nums[i + 1]

思路:

二分。从mid点开始爬坡,只要是向上走(numsmid<pre 、 numsmid<after),在这个向上的部分,一定会出现峰值(即便一直递增爬坡,边界也会是峰值)

python 复制代码
from typing import List


class Solution:
    def findPeakElement(self, nums: List[int]) -> int:
        left,right=0,len(nums)-1
        while left<=right:
            mid=left+(right-left)//2
            pre=nums[mid-1] if mid>0 else -float('inf')
            after=nums[mid+1] if mid<len(nums)-1 else -float('inf')
            if nums[mid]>pre and nums[mid]>after:
                return mid
            elif nums[mid]<after:
                left=mid+1
            else:
                right=mid-1
        return -1
相关推荐
noipp1 小时前
推荐题目:洛谷 P1115 最大子段和
算法
Lumbrologist1 小时前
【C++】零基础入门 · 第 17 节:多线程编程基础
java·c++·算法
tkevinjd1 小时前
事务、ACID与隔离
java·数据库·sql
阿洛学长1 小时前
Kali Linux 虚拟机安装(VMware Workstation 17)
java·linux·服务器
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第91题】【Mysql篇】第21题:分布式锁的使用场景和原理?
java·数据库·分布式·mysql·面试
JAVA社区1 小时前
Java高级全套教程(十三)—— 分布式锁超详细实战详解(原理+三种方案企业级落地)
java·开发语言·分布式·spring cloud·面试·java-zookeeper
前端与小赵1 小时前
Python 模块导入全解析,从基础语法到循环导入破解
python
Mahir081 小时前
MyBatis 延迟加载深度解密:从使用方式到底层动态代理原理全解
java·后端·面试·mybatis
超梦dasgg1 小时前
Java 生产环境 Maven 实战指南
java·开发语言·maven