原题链接:关于圆的面积
参考代码:
#include<stdio.h>
#include<math.h>
#define PI 3.1415926
int main()
{
int t;
double x1, y1, x2, y2, r1, r2, d, ans;
scanf("%d", &t);
while(t--){
scanf("%lf%lf%lf%lf%lf%lf", &x1, &y1, &x2, &y2, &r1, &r2);
d = sqrt(pow((x1 - x2), 2) + pow((y1 - y2), 2)); // 圆心距d
if(d >= (r1 + r2)) ans = 0; // 相离或外切
else if(d <= fabs(r1 - r2)){ // 内切或内含
ans = r1 < r2 ? PI * r1 * r1 : PI * r2 * r2;
}
else{ // 相交
double A1 = 2 * acos((r1 * r1 + d * d - r2 * r2) / (2 * r1 * d));
double A2 = 2 * acos((r2 * r2 + d * d - r1 * r1) / (2 * r2 * d));
double S1 = A1 / 2 * r1 * r1 + A2 / 2 * r2 * r2;
double S2 = r1 * r1 * sin(A1) / 2 + r2 * r2 * sin(A2) / 2;
ans = S1 - S2;
}
printf("%.3lf\n", ans);
}
return 0;
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复