题解 | #寻找峰值#
寻找峰值
https://www.nowcoder.com/practice/fcf87540c4f347bcb4cf720b5b350c76
直接二分
/** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param nums int整型一维数组 * @return int整型 */ function findPeakElement(nums) { // write code here let len = nums.length, l = 0, r = len - 1; if (len === 1) { return 0; } if (len === 2) { return nums[1] > nums[0] ? 1 : 0; } while (l <= r) { let m = l + Math.floor((r - l) >> 1); let mm = nums[m]; if (mm > nums[m - 1] && mm > nums[m + 1]) { return m; } if ((mm > nums[m - 1] && m === len - 1) || (mm > nums[m + 1] && m === 0)) { return m; } if (mm > nums[m - 1] && mm < nums[m + 1]) { l = m + 1; } else { r = m - 1; } } return -1; } module.exports = { findPeakElement: findPeakElement, };