二分查找的本质
- 二分查找的本质是
二段性,二分查找的过程本质是对可行区间的压缩,只要满足二段性的问题都可以用二分查找解决。 - 此题的二段性体现在峰值的左边单调增,右边单调减。
二分查找的分类
- 左闭右开型:while循环中,left和right之间没有等号,中间值选取为mid=(left+right)/2,中间值偏向左边,是左闭右开型,适合用于寻找上界。
- 左开右闭型:while循环中,left和right之间没有等号,中间值选取为mid=(left+right+1)/2,中间值偏向右边,是左开右闭型,适合用于寻找下界。
使用左闭右开型二分查找寻找峰值
- 根据首尾指针确定一个中间值,如果这个中间值大于右边相邻的值,说明这个中间值有可能是峰值,下次在[left, mid)中寻找峰值。
- 如果中间值小于右边相邻的值,此时处于上坡阶段,这个中间值不可能是峰值,下次在[mid+1, right)中寻找峰值。
参考
https://blog.csdn.net/whc18858/article/details/122379930?spm=1001.2014.3001.5501
https://blog.nowcoder.net/n/a9a4a9f3b09f46d38d2dd80e1a7f272d?f=comment
https://blog.nowcoder.net/n/eafbb55131ec4e7f83360ed84c7ad911?f=comment
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型一维数组
* @return int整型
*/
function findPeakElement( nums ) {
// write code here
let left = 0;
let right = nums.length-1;
let middle;
while (left < right) {
middle = Math.floor((left+right)/2);
if (nums[middle] < nums[middle+1]) {
// 说明此时在上坡,峰值在右边区间
left = middle+1;
}
else if (nums[middle] > nums[middle+1]){
// 说明此时在下坡,middle可能是峰值
right = middle;
}
}
return left;
}
module.exports = {
findPeakElement : findPeakElement
};



京公网安备 11010502036488号