问题描述:
给你一个数组 rectangles ,其中 rectangles[i] = [xi, yi, ai, bi] 表示一个坐标轴平行的矩形。这个矩形的左下顶点是 (xi, yi) ,右上顶点是 (ai, bi) 。
如果所有矩形一起精确覆盖了某个矩形区域,则返回 true ;否则,返回 false 。
示例 1:
输入:rectangles = [[1,1,3,3],[3,1,4,2],[3,2,4,4],[1,3,2,4],[2,3,3,4]]
输出:true
解释:5 个矩形一起可以精确地覆盖一个矩形区域。
示例 2:
输入:rectangles = [[1,1,2,3],[1,3,2,4],[3,1,4,2],[3,2,4,4]]
输出:false
解释:两个矩形之间有间隔,无法覆盖成一个矩形。
示例 3:
输入:rectangles = [[1,1,3,3],[3,1,4,2],[1,3,2,4],[3,2,4,4]]
输出:false
解释:图形顶端留有空缺,无法覆盖成一个矩形。
示例 4:
输入:rectangles = [[1,1,3,3],[3,1,4,2],[1,3,2,4],[2,2,4,4]]
输出:false
解释:因为中间有相交区域,虽然形成了矩形,但不是精确覆盖。
提示:
1 <= rectangles.length <= 2 * 10^4
rectangles[i].length == 4
-105 <= xi, yi, ai, bi <= 10^5
解决方案:
官方题解(哈希表):
typedef pair<int, int> Point;
class Solution {
public:
bool isRectangleCover(vector<vector<int>>& rectangles) {
long area = 0;
int minX = rectangles[0][0], minY = rectangles[0][1], maxX = rectangles[0][2], maxY = rectangles[0][3];
map<Point, int> cnt;
for (auto & rect : rectangles) {
int x = rect[0], y = rect[1], a = rect[2], b = rect[3];
area += (long) (a - x) * (b - y);
minX = min(minX, x);
minY = min(minY, y);
maxX = max(maxX, a);
maxY = max(maxY, b);
Point point1({x, y});
Point point2({x, b});
Point point3({a, y});
Point point4({a, b});
cnt[point1] += 1;
cnt[point2] += 1;
cnt[point3] += 1;
cnt[point4] += 1;
}
Point pointMinMin({minX, minY});
Point pointMinMax({minX, maxY});
Point pointMaxMin({maxX, minY});
Point pointMaxMax({maxX, maxY});
if (area != (long long) (maxX - minX) * (maxY - minY) || !cnt.count(pointMinMin) || !cnt.count(pointMinMax) || !cnt.count(pointMaxMin) || !cnt.count(pointMaxMax)) {
return false;
}
cnt.erase(pointMinMin);
cnt.erase(pointMinMax);
cnt.erase(pointMaxMin);
cnt.erase(pointMaxMax);
for (auto & entry : cnt) {
int value = entry.second;
if (value != 2 && value != 4) {
return false;
}
}
return true;
}
};