LeetCode如何寻找峰值
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,这篇文章给大家分享的是有关LeetCode如何寻找峰值的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。题目描述峰值元素是指其值大于左右相邻值的元素。给定一个输入数组 nums
千家信息网最后更新 2025年12月03日LeetCode如何寻找峰值
算法动图
这篇文章给大家分享的是有关LeetCode如何寻找峰值的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
题目描述
峰值元素是指其值大于左右相邻值的元素。
给定一个输入数组 nums,其中 nums[i] ≠ nums[i+1],找到峰值元素并返回其索引。
数组可能包含多个峰值,在这种情况下,返回任何一个峰值所在位置即可。
你可以假设 nums[-1] = nums[n] = -∞。
示例 1:
输入: nums = [1,2,3,1]输出: 2解释: 3 是峰值元素,你的函数应该返回其索引 2。
示例 2:
输入: nums = [1,2,1,3,5,6,4]输出: 1 或 5 解释: 你的函数可以返回索引 1,其峰值元素为 2; 或者返回索引 5, 其峰值元素为 6。
说明:
你的解法应该是 O(logN) 时间复杂度的。
解题方案
思路
标签:二分查找
过程:
首先要注意题目条件,在题目描述中出现了
nums[-1] = nums[n] = -∞,这就代表着只要数组中存在一个元素比相邻元素大,那么沿着它一定可以找到一个峰值根据上述结论,我们就可以使用二分查找找到峰值
查找时,左指针l,右指针r,以其保持左右顺序为循环条件
根据左右指针计算中间位置m,并比较m与m+1的值,如果m较大,则左侧存在峰值,r=m,如果m+1较大,则右侧存在峰值,l=m+1
时间复杂度:O(logN)
代码
class Solution { public int findPeakElement(int[] nums) { int left = 0, right = nums.length - 1; for (; left < right; ) { int mid = left + (right - left) / 2; if (nums[mid] > nums[mid + 1]) { right = mid; } else { left = mid + 1; } } return left; }}感谢各位的阅读!关于"LeetCode如何寻找峰值"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
峰值
元素
索引
指针
数组
题目
输入
复杂
较大
位置
内容
函数
复杂度
时间
更多
条件
示例
篇文章
解释
输出
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
常用的数据库备份方法有哪三种
有几种网络技术有限公司
电商购物软件开发中心
我的世界服务器计分板颜色
机架式式服务器图片
宿迁云主机服务器供货厂
戴尔服务器经销商苏州
基层执法数据库建设
软件开发创新建议
成都看客网络技术有限公司
网络安全陪我行小学小报
内蒙古学生网络技术开发建议
服务器500错误怎么解决
加固服务器哪家信誉好
数据库技术考试难不难
MSQL数据库表能多大
数据库中 显示时间
更改数据库连接ip
网络安全知识点框架图
秦皇岛网络安全公司林浩
萧山区直播软件开发
网络安全搞笑文案
信息网络安全第一责任人
网络安全工程师所需要的知识
软件开发课程结束图片
wpf的api数据库
linuxdns服务器
银保监网络安全应急预案
静安区新型软件开发模板规格
达梦数据库和SQL