使用C ++查找两个矩形是否重叠。
我们知道,可以使用两个坐标(左上角和右下角)来表示矩形。假设有两个矩形,我们必须检查这两个矩形是否重叠。有四个坐标点(l1,r1)和(l2,r2)。
l1是第一个矩形的左上角
r1是第一个矩形的右下角
l2是第二个矩形的左上角
r2是第二个矩形的右下角
我们假设矩形与坐标轴平行。为了解决这个问题,我们必须检查一些条件。
一个矩形位于另一个矩形的顶部边缘上方
一个矩形位于另一个矩形左边缘的左侧。
示例
#include<iostream>
using namespace std;
class Point {
public:
int x, y;
};
bool isOverlapping(Point l1, Point r1, Point l2, Point r2) {
if (l1.x > r2.x || l2.x > r1.x)
return false;
if (l1.y < r2.y || l2.y < r1.y)
return false;
return true;
}
int main() {
Point l1 = {0, 10}, r1 = {10, 0};
Point l2 = {5, 5}, r2 = {15, 0};
if (isOverlapping(l1, r1, l2, r2))
cout << "Rectangles are Overlapping";
else
cout << "Rectangles are not Overlapping";
}输出结果
Rectangles are Overlapping