mirror of
https://github.com/lWolvesl/leetcode.git
synced 2026-01-12 18:08:38 +08:00
29 lines
804 B
C++
29 lines
804 B
C++
#include <vector>
|
|
|
|
class Solution {
|
|
public:
|
|
int countCoveredBuildings(int n, std::vector<std::vector<int>>& buildings) {
|
|
std::vector<int> maxX(n + 1);
|
|
std::vector<int> minX(n + 1, n + 1);
|
|
std::vector<int> maxY(n + 1);
|
|
std::vector<int> minY(n + 1, n + 1);
|
|
|
|
for (auto &p : buildings) {
|
|
int x = p[0], y = p[1];
|
|
maxX[y] = std::max(maxX[y], x);
|
|
minX[y] = std::min(minX[y], x);
|
|
maxY[x] = std::max(maxY[x], y);
|
|
minY[x] = std::min(minY[x], y);
|
|
}
|
|
|
|
int res = 0;
|
|
for (auto &p : buildings) {
|
|
int x = p[0], y = p[1];
|
|
if (x > minX[y] && x < maxX[y] && y > minY[x] && y < maxY[x]) {
|
|
res++;
|
|
}
|
|
}
|
|
|
|
return res;
|
|
}
|
|
}; |