解题思路:我是看了一下这里的题解再做的,一开始确实忽略了很重要的就是矩形边和坐标轴平行,我还傻乎乎的分好多种情况,
注意事项:
参考代码:
#include <stdio.h>
#define max(a,b) (((a)>(b))?(a):(b))
#define min(a,b) (((a)<(b))?(a):(b))
int main()
{
double a1,a2,b1,b2;
double x1,x2,y1,y2;
double m1,m2,n1,n2;
scanf("%lf %lf %lf %lf",&a1,&b1,&a2,&b2);
scanf("%lf %lf %lf %lf",&x1,&y1,&x2,&y2);
m1=max(min(a1,a2),min(x1,x2));
n1=max(min(b1,b2),min(y1,y2));
m2=min(max(a1,a2),max(x1,x2));
n2=min(max(b1,b2),max(y1,y2));
if(m1>=m2||n1>=n2)printf("0.00\n");
else printf("%.2lf\n",(m2-m1)*(n2-n1));
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复