-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy path0162_Find-Peak-Element.cpp
More file actions
37 lines (32 loc) · 1.01 KB
/
0162_Find-Peak-Element.cpp
File metadata and controls
37 lines (32 loc) · 1.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
class Solution {
public:
using vn = vector<int>;
bool equal(vn &nums, int mid) {
bool minus_1_ok = (mid == 0) ? true : nums[mid - 1] < nums[mid];
bool plus_1_ok =
(mid == nums.size() - 1) ? true : nums[mid] > nums[mid + 1];
return minus_1_ok && plus_1_ok;
}
bool is_increment(vn &nums, int mid) {
bool minus_1_ok = (mid == 0) ? true : nums[mid - 1] < nums[mid];
bool plus_1_ok =
(mid == nums.size() - 1) ? true : nums[mid] < nums[mid + 1];
return minus_1_ok && plus_1_ok;
}
int findPeakElement(vector<int> &nums) {
// binary search
// write our own compare function
int l = 0, r = nums.size() - 1;
while (l <= r) {
int mid = l + ((r - l) >> 1);
if (equal(nums, mid)) {
return mid;
} else if (is_increment(nums, mid)) {
l = mid + 1;
} else {
r = mid - 1;
}
}
return l;
}
};