蓝桥杯训练-矩形面积交(day11)

一、题目

平面上有两个矩形,他们的边平行于直角坐标系的x轴或y轴。对于每个矩形,我们给出它的一对相对顶点坐标,请你算出两个矩形交的面积。

输入:

仅包含两行,每一行描述一个矩形。

在每行中,给出矩形的一对相对顶点坐标,每个坐标都用两个绝对值不超过10^7的实数表示。

输出:

输出一个实数,为交的面积,保留到小数点后两位。

二、例子

输入:

1 1 3 3

2 2 4 4

输出:

1.00

三、解析

不相交的两种情况:

1.c<=a2,即代码中的x2 - x1 <= 0

蓝桥杯训练-矩形面积交(day11)_第1张图片

2.d<=b2,即代码中y2 - y1 <= 0

蓝桥杯训练-矩形面积交(day11)_第2张图片相交的情况得出规律:不论哪种相交,相交矩形的长都是两个矩形横坐标的中间两个值之差[例:下面第三个图相交矩形长度为{a,a2,c,c2的中间值a2,c之差:c-a2}],相交矩形的宽都是两个矩形纵坐标的中间两个值之差。

蓝桥杯训练-矩形面积交(day11)_第3张图片

注意:可能习惯输入1133,若为3311怎么办?首先调整成1133 

四、python代码及逐行解析

a = list(map(float,input().split()))  #输入矩形1一对顶点坐标
b = list(map(float,input().split()))  #输入矩形2一对顶点坐标
area = 0         #面积
if a[0] > a[2]:  #排序,将横纵坐标小的放前面
    a[0],a[2] = a[2],a[0]
if a[1] > a[3]:
    a[1],a[3] = a[3],a[1]
if b[0] > b[2]:
    b[0],b[2] = b[2],b[0]
if b[1] > b[3]:
    b[1],b[3] = b[3],b[1]
x1 = max(a[0],b[0]) #相交矩形左横坐标
y1 = max(a[1],b[1]) #相交矩形下纵坐标
x2 = min(a[2],b[2]) #相交矩形右横坐标
y2 = min(a[3],b[3]) #相交矩形上纵坐标
if x2 - x1 <= 0 or y2 - y1 <= 0: #不相交的两种情况
    area=0
else:
    length = x2 - x1 #相交矩形的长
    width = y2 - y1  #相交矩形的宽
    area = length * width #相交矩形的面积
print("%.2f"%area)

运行结果:

1 1 3 3
2 2 4 4
1.00

你可能感兴趣的:(蓝桥杯,蓝桥杯,python)