题解 | #寻找峰值#

寻找峰值

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


问题:只要返回随便一个峰值的索引即可
nums[i] !== nums[i+1], 可以推出以x为参考点任何一边都可能存在峰值,有点类似爬坡
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param nums int整型一维数组
 * @return int整型
 */
function findPeakElement(nums) {
    // write code here
    let left = 0,
        right = nums.length - 1;
    while (left < right) {
        const mid = Math.floor(left + (right - left) / 2);
        // 上坡
        if (nums[mid] > nums[mid + 1]) {
            if (mid === 0 || nums[mid - 1] < nums[mid]) {
                return mid;
            }
            right = mid;
        } else {
            left = mid + 1;
        }
    }
    return left;
}
module.exports = {
    findPeakElement: findPeakElement,
};

全部评论

相关推荐

点赞 评论 收藏
分享
码农索隆:这种hr,建议全中国推广
点赞 评论 收藏
分享
牛客刘北:如果暑期实习是27届的话,你要晚一年才会毕业,企业为什么会等你呢?要搞清时间逻辑呀!27届现在实习只能是在暑假实习,这是日常实习,不是暑期实习。所以多去投日常实习吧,暑期实习肯定不会要你的
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-02 15:39
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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