/* 矩形面积交;我们把x轴和y轴分开思考,画出一两个图就会发现如何找; 
%f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。
其中:
float,单精度浮点型,对应%f.
double,双精度浮点型,对应%lf.
在用于输出时:
float类型可以使用%lf格式,但不会有任何好处。
double类型如果使用了%f格式可能会导致输出错误。
在用于输入时:
double 类型使用了%f格式,会导致输入值错误。
float类型使用double类型不仅会导致输入错误,还可能引起程序崩溃。
所以在输入输出时,一定要区分好double和float,而使用对应的格式符号。
*/ 
#include <stdio.h>
#define min(x,y) ((x)<(y)?(x):(y))
#define max(x,y) ((x)>(y)?(x):(y))
int main()
{
 double x1,x2,x3,x4;
 double y1,y2,y3,y4;
 double m1,n1,m2,n2;
 scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);  
 scanf("%lf%lf%lf%lf",&x3,&y3,&x4,&y4);
 m1=max(min(x1,x2),min(x3,x4));
 m2=min(max(x1,x2),max(x3,x4));
 n1=max(min(y1,y2),min(y3,y4));
 n2= min(max(y1,y2),max(y3,y4));
 if(m1>=m2||n1>=n2) printf("0.00\n");        //条件必须用或;
 else printf("%.2f\n",(m2-m1)*(n2-n1));
 return 0;
 }

解题思路:





注意事项:





参考代码:

点赞(1)
 

0.0分

16 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 3 条评论

是雪花呀 2年前 回复TA
这是怎么想到的,太强了
小小的翅膀 3年前 回复TA
厉害厉害,我写了快100行代码才做出来
Hainui 3年前 回复TA
这是真厉害 !! 又来看一遍