LeetCode-162.寻找峰值

本文详细解析了在给定数组中寻找峰值元素的算法实现,峰值元素定义为大于左右相邻值的元素。通过示例代码展示了如何遍历数组并判断每个元素是否为峰值,最终返回峰值元素的索引。

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

  给定一个输入数组 nums,其中 nums[i] ≠ nums[i+1],找到峰值元素并返回其索引。

  数组可能包含多个峰值,在这种情况下,返回任何一个峰值所在位置即可。

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

  

  

 1 class Solution {
 2     public int findPeakElement(int[] nums) {
 3         if(nums.length==1)  return 0;
 4         for(int i=0;i<nums.length;i++){
 5             int l=(i-1)<0?Integer.MIN_VALUE:nums[i-1];
 6             int r=(i+1)==nums.length?Integer.MIN_VALUE:nums[i+1];
 7             //如果是峰值,即当前元素大于左右相邻值,直接返回索引
 8             if(nums[i]>l&&nums[i]>r)    return i;
 9             //若当前元素大于下一个元素时,可知下一个元素也不是峰值,进行i++,跳过
10             if(r<nums[i])   i++;
11         }
12         return -1;
13     }
14 }

 

转载于:https://www.cnblogs.com/lyh28/p/10744145.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值