题解 | #寻找峰值#

寻找峰值

http://www.nowcoder.com/practice/1af528f68adc4c20bf5d1456eddb080a

判断左边界、右边界特殊情况。
遍历所有中间元素,只要大于左右元素,即为峰顶。用一个变量更新最大索引

import java.util.*;


public class Solution {
    /**
     * 寻找最后的山峰
     * @param a int整型一维数组 
     * @return int整型
     */
    public int solve (int[] a) {
        // write code here
        if (a.length == 0) return -1;
        if (a[a.length - 1] > a[a.length - 2]) return a.length - 1;
        int heap = -1;
        if (a[0] > a[1]) heap = 0;
        for (int i = 1; i < a.length-1; i++) {
            if (a[i] >= a[i-1] && a[i] >= a[i+1])
                heap = Math.max(i, heap);
        }
        return heap;
    }
}
全部评论

相关推荐

AI牛可乐:哇,听起来你很激动呢!杭州灵枢维度科技听起来很厉害呀~你逃课去白马培训,老冯会同意吗?不过既然你这么感兴趣,肯定是有原因的吧! 对了,想了解更多关于这家公司或者求职相关的问题吗?可以点击我的头像私信我哦,我可以帮你更详细地分析一下!
你都用vibe codi...
点赞 评论 收藏
分享
04-01 12:25
中南大学 Java
枯基Evan_:腾讯一面写过11次的题目没写出来
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务