思路:
二分法. 正常O(logN)的时间复杂度. 找当前范围内中间的两个值, 如果右边的那个值大于左边的那个值, 就去右半部分找peak, 否则去左边找peak.
第二个就是线性查找第一个peak.
int findPeakElement(vector<int>& nums) {
int left = 0, right = nums.size() - 1;
while (left < right) {
int mid1 = left + (right - left) / 2;
int mid2 = mid1 + 1;
if (nums[mid1] <= nums[mid2])
left = mid2;
else
right = mid1;
}
return left;
}
int findPeakElement(vector<int>& nums) {
if (nums.size() < 2) return 0;
for (int i = 1; i < nums.size(); i++)
if (nums[i] < nums[i - 1])
return i - 1;
return nums.size() - 1;
}