在一个平面坐标系上,有两个矩形,它们的边分别平行于X和Y轴。
其中,矩形A已知, ax1(左边), ax2(右边), ay1(top的纵坐标), ay2(bottom纵坐标). 矩形B,类似,就是 bx1, bx2, by1, by2。这些值都是整数就OK了。
要求是,如果矩形没有交集,返回-1, 有交集,返回交集的面积。
int area(rect const& a, rect const& b)
{
...
其中,矩形A已知, ax1(左边), ax2(右边), ay1(top的纵坐标), ay2(bottom纵坐标). 矩形B,类似,就是 bx1, bx2, by1, by2。这些值都是整数就OK了。
要求是,如果矩形没有交集,返回-1, 有交集,返回交集的面积。
int area(rect const& a, rect const& b)
{
...
}
typedef struct rect {
int x[2]; //x[0]:x1 x[1]:x2
int y[2]; //y[0]:y2 y[1]:y1
} Rect;
int area(rect const& a, rect const& b) {
int difX = min(a.x[1], b.x[1]) - max(a.x[0], b.x[0]);
int difY = min(a.y[1], b.y[1]) - max(a.y[0], b.y[0]);
return (difX < 0 || difY < 0) ? -1 : difX * difY;
}