题解 | #寻找峰值#

寻找峰值

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

nums[-1] = nums[n] = -∞
1 <= 数组长度 <= 1000
0 <= 数组元素的值 <= 1000

重新创建数组arr,第一个与最后一个元素设为-1,其它元素依次为参数数组a元素,再遍历arr数组,arr.index = [1, a.length]

import java.util.*;


public class Solution {
    /**
     * 寻找最后的山峰
     * @param a int整型一维数组 
     * @return int整型
     */
    public int solve (int[] a) {
        // write code here
        int[] arr = new int[a.length + 2];
        arr[0] = -1;
        arr[a.length + 1] = -1;

        for (int i = 0; i < a.length; i ++) {
            arr[i + 1] = a[i];
        }

        // 峰值索引
        int index = -1;

        for (int i = 1; i < a.length + 1; i++) {

            boolean boo = (arr[i] > arr[i - 1] && arr[i] > arr[i + 1]) 
                    || (arr[i] == arr[i - 1] && arr[i] == arr[i + 1]); 

                if (boo) {
                    index = i - 1;
                }        
        }
        return index;
    }
}
全部评论

相关推荐

06-20 17:42
东华大学 Java
凉风落木楚山秋:要是在2015,你这简历还可以月入十万,可惜现在是2025,已经跟不上版本了
我的简历长这样
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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