-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
maximum-number-of-intersections-on-the-chart.cpp
58 lines (56 loc) · 1.99 KB
/
maximum-number-of-intersections-on-the-chart.cpp
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// Time: O(nlogn)
// Space: O(n)
// sort, line sweep, coordinate compression
class Solution {
public:
int maxIntersectionCount(vector<int>& y) {
unordered_set<int> set_y(cbegin(y), cend(y));
vector<int> sorted_set_y(cbegin(set_y), cend(set_y));
sort(begin(sorted_set_y), end(sorted_set_y));
unordered_map<int, int> val_to_idx;
for (int i = 0; i < size(sorted_set_y); ++i) {
val_to_idx[sorted_set_y[i]] = i;
}
vector<int> cnts(2 * size(val_to_idx) + 1);
for (int i = 0; i + 1 < size(y); ++i) {
// [y[i], y[i+1]) <=> [y[i], y[i+1]-0.5] <=> [2*y[i], 2*y[i+1]-1]
const int left = 2 * val_to_idx[y[i]], right = 2 * val_to_idx[y[i + 1]] + (y[i] < y[i + 1] ? -1 : +1);
++cnts[min(left, right)];
--cnts[max(left, right) + 1];
}
// [y[i], y[i]] <=> [2*y[i], 2*y[i]]
++cnts[2 * val_to_idx[y.back()]];
--cnts[2 * val_to_idx[y.back()] + 1];
int result = 0, cnt = 0;
for (const auto& c : cnts) {
cnt += c;
result = max(result, cnt);
}
return result;
}
};
// Time: O(nlogn)
// Space: O(n)
// sort, line sweep
class Solution2 {
public:
int maxIntersectionCount(vector<int>& y) {
vector<pair<int, int>> events;
for (int i = 0; i + 1 < size(y); ++i) {
// [y[i], y[i+1]) <=> [y[i], y[i+1]-0.5] <=> [2*y[i], 2*y[i+1]-1]
const int left = 2 * y[i], right = 2 * y[i + 1] + (y[i] < y[i + 1] ? -1 : +1);
events.emplace_back(min(left, right), +1);
events.emplace_back(max(left, right) + 1, -1);
}
// [y[i], y[i]] <=> [2*y[i], 2*y[i]]
events.emplace_back(2 * y.back(), +1);
events.emplace_back(2 * y.back() + 1, -1);
sort(begin(events), end(events));
int result = 0, cnt = 0;
for (const auto& [_, c] : events) {
cnt += c;
result = max(result, cnt);
}
return result;
}
};