1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| class Solution { public: int findPeakElement(vector<int>& nums) { int n = nums.size(); int l = 0, r = n - 1; while (l <= r) { int m = l + (r - l) / 2; if ((m == 0 || nums[m - 1] < nums[m]) && (m == n - 1 || nums[m] > nums[m + 1])) { return m; } else if (m == 0 || nums[m - 1] < nums[m]) { l = m + 1; } else { r = m - 1; } } return -1; } };
|