原题链接:蓝桥杯基础练习VIP-矩形面积交
/* 矩形面积交;我们把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; }
解题思路:
注意事项:
参考代码:
0.0分
16 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复