题解 | #寻找峰值#

寻找峰值

https://www.nowcoder.com/practice/fcf87540c4f347bcb4cf720b5b350c76

思路:
1、从数组的第二个元素开始,判断是否为峰值;
2、如果不是峰值,则i = i+2,间隔一个再进行循环判断
3、如果上述步骤无法判断出峰值,则峰值肯定在第一个元素或者最后一个元素

需要循环n/2次,这种思路不太好,但是也是一种解法吧。

public static int findPeakElement (int[] nums) {
        if (nums == null || nums.length == 0) {
            return 0;
        }
        int i = 1;
        while (i < nums.length) {
            if (nums[i] > nums[i - 1] && nums[i] > nums[i+1]){
                return  i;
            }
            i += 2;
        }
        return nums[0] > nums[nums.length -  1] ? 0 : nums.length - 1;
    }
我的刷题题解 文章被收录于专栏

自己在刷题过程中的一些思路和见解记录

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务