题解 | #寻找峰值#
寻找峰值
https://www.nowcoder.com/practice/fcf87540c4f347bcb4cf720b5b350c76
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型vector
* @return int整型
*/
int findPeakElement(vector<int>& nums) {
// write code here
// if(nums.size()==1)return 0;
// if(nums.size()==2){
// if(nums[0]>nums[1])return 0;
// else if(nums[0]<nums[1])return 1;
// }
// for(int i=1;i<nums.size();i++){
// if(nums[i-1]<nums[i]&&nums[i]>nums[i+1])return i;
// }
// if(nums[0]>nums[1])return 0;
// if(nums[nums.size()-1]>nums[nums.size()-2])return nums.size()-1;
// return 0;
int left=0;
int right=nums.size()-1;
while(left<right){
int mid=left+(right-left)/2;
if(nums[mid]<nums[mid+1])left=mid+1;
else right=mid;
}
return right;
}
};
用二分查找很快
如果nums[mid]<nums[mid+1],说明是在上坡,那就继续上,直到峰顶
如果nums[mid]<nums[mid+1],说明是在下坡,那就往上走,找峰顶
当left=right,就是峰顶

查看9道真题和解析