题解 | #寻找峰值#

寻找峰值

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,
};

全部评论

相关推荐

09-19 13:59
门头沟学院 Java
用微笑面对困难:Trae一下,如果真成了,他用了直接发字节起诉代码版权,,这个代码不商用是没问题的如果没成也是情理之中的。
点赞 评论 收藏
分享
牛客21331815...:像我一投就pass,根本不用焦虑泡池子
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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