在二维平面上,给定两个矩形,满足矩形的每条边分别和坐标轴平行,求这个两个矩形的并的面积。即它们重叠在一起之后的总的面积。
输入
8个数,分别表示第一个矩形左下角坐标为(A,B),右上角坐标为(C,D);第二个矩形左下角坐标为(E,F),右上角坐标为(G,H)。
保证A<C,B<D,E<G,F<H。
保证所有数的绝对值不超过2*109,矩形并的面积≤2*109。
输出
输出一个数表示矩阵并的面积。
输入样例
-3 0 3 4 0 -1 9 2
输出样例
45
#include<bits/stdc++.h>
using namespace std;
int main()
{
ios::sync_with_stdio(false);
int a,b,c,d,e,f,g,h;
cin>>a>>b>>c>>d>>e>>f>>g>>h;
if(b>=h||f>=d||c<=e||g<=a)//不相交
{
cout<<(c-a)*(d-b)+(g-e)*(h-f);
}
else //总面积-重叠的面积
{
cout<<(c-a)*(d-b)+(g-e)*(h-f)-abs((max(f,b)-min(d,h))*(max(a,e)-min(c,g)));
}
return 0;
}