参考代码:


#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分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论