题解 | #寻找峰值#

寻找峰值

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;
    }
我的刷题题解 文章被收录于专栏

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

全部评论

相关推荐

06-10 21:15
门头沟学院 Java
宁阿:好多这种没🧠的公司,他们估计都不知道毕业的人不能给安排实习岗
实习吐槽大会
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 13:35
虽然不怎么光彩,经过这件事,可能我真的要去认同“面试八股文早该淘汰!不会用AI作弊的程序员=新时代文盲!”这句话了
HellowordX:Ai的出现是解放劳动力的,不是用来破坏公平竞争环境的,这样下去,轻则取消所有线上面试,严重了会影响整个行业对所有人产生影响,企业会拉高入职考核各种离谱考核会层出不穷
你找工作的时候用AI吗?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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