简介
leetcode 原题链接:矩形重叠
- 描述
矩形以列表 [x1, y1, x2, y2] 的形式表示,其中 (x1, y1) 为左下角的坐标,(x2, y2) 是右上角的坐标。
如果相交的面积为正,则称两矩形重叠。需要明确的是,只在角或边接触的两个矩形不构成重叠。
给出两个矩形,判断它们是否重叠并返回结果。
示例 1:
输入:rec1 = [0,0,2,2], rec2 = [1,1,3,3]
输出:true
示例 2:
输入:rec1 = [0,0,1,1], rec2 = [1,0,2,1]
输出:false
bool isRectangleOverlap(int* rec1, int rec1Size, int* rec2, int rec2Size){
}
思路
这道题可以从反向来思考,排除那些不满足条件的情况,那么其他的就都是满足条件的。不满足条件的情况如下图所示,
我们定义rec1 为上图中灰色的矩形,rec2为图中绿色的矩形,1,2,3,4的四个灰色矩形位置分别是四种不和rec2重叠的情况。
- 对于情况1来说: x2 <= x1’
- 对于情况2来说: y2 <= y1’
- 对于情况3来说: x1 >= x2’
- 对于情况4来说: y1 >= y2’
排除掉这4中情况,其他情况都会重叠。
- 代码
bool isRectangleOverlap(int* rec1, int rec1Size, int* rec2, int rec2Size){
return (rec1[2]<=rec2[0]||rec1[3]<=rec2[1]||rec1[0]>=rec2[2]||rec1[1]>=rec2[3]) ? false : true;
}