1.题目
题目 1471: 蓝桥杯基础练习VIP-矩形面积交
时间限制: 1Sec 内存限制: 128MB
题目描述
平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴。对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积。
输入
输入仅包含两行,每行描述一个矩形。 在每行中,给出矩形的一对相对顶点的坐标,每个点的坐标都用两个绝对值不超过10^7的实数表示。
输出
输出仅包含一个实数,为交的面积,保留到小数后两位。
样例输入复制
1 1 3 3 2 2 4 4
样例输出复制
1.00
2.思路
由几何关系分析得在有相交的时候到相交矩形的坐标表示通式
x1 = max(min(l1[0],l1[2]),min(l2[0],l2[2])) ##相交矩形的横坐标最小值
x2 = min(max(l1[0],l1[2]),max(l2[0],l2[2])) ##相交矩形的横坐标最大值
y1 = max(min(l1[1],l1[3]),min(l2[1],l2[3])) ##相交矩形的纵坐标最小值
y2 = min(max(l1[1],l1[3]),max(l2[1],l2[3])) ##相交矩形的纵坐标最大值
无相交的时候面积为0
3.代码【python】
l1 = list(map(float,input().strip().split())) ##输入第一行
l2 = list(map(float,input().strip().split())) ##输入第二行
x1 = max(min(l1[0],l1[2]),min(l2[0],l2[2])) ##相交矩形的横坐标最小值
x2 = min(max(l1[0],l1[2]),max(l2[0],l2[2])) ##相交矩形的横坐标最大值
y1 = max(min(l1[1],l1[3]),min(l2[1],l2[3])) ##相交矩形的纵坐标最小值
y2 = min(max(l1[1],l1[3]),max(l2[1],l2[3])) ##相交矩形的纵坐标最大值
if x2>x1 and y2>y1: ##矩形相交
areas = (x2-x1)*(y2-y1)
else:
areas = 0 ##矩形不相交
print(areas)