HDU5120-Intersection-两个圆环相交面积
终究还是我太蠢了!!!!
原来这是两个同心圆的相交部分,(最中间是空的)我画的1和2部分加起来就是了。
无法理解字面意思。害
题意:计算两个一样的圆环相交的面积,给出r1小的圆的半径,r2是大的圆的半径,接下去给出两行x、y,代表两个圆环的圆心。
思路:
两个大的圆的相交部分-左边大圆和右边小圆的相交部分-左边小圆和右边大圆的相交部分+左右小圆的相交部分。
AC代码:

1 #include<iostream> 2 #include<stdio.h> 3 #include<algorithm> 4 #include<cmath> 5 #include<string.h> 6 7 using namespace std; 8 typedef long long ll; 9 #define inf 0x3f3f3f3f 10 #define PI acos(-1.0)//不是-1 11 #define eps 1e-9 12 13 struct node 14 { 15 int x,y; 16 }a,b; 17 18 double s(double r1,double r2) 19 { 20 double d=sqrt((a.x-b.x)*(a.x-b.x)*1.0+(a.y-b.y)*(a.y-b.y)*1.0); 21 if(r1+r2<d+eps) 22 return 0;//相离 23 if(d<fabs(r1-r2)+eps) 24 { 25 double minn=min(r1,r2); 26 return PI*minn*minn; 27 } 28 double t=(d*d+r1*r1-r2*r2)/(2*d); 29 double x=acos(t/r1),y=acos((d-t)/r2); 30 return r1*r1*x+r2*r2*y-d*r1*sin(x); 31 } 32 33 int main() 34 { 35 int T,cas=1; 36 scanf("%d",&T); 37 while(T--) 38 { 39 double r1,r2; 40 scanf("%lf %lf",&r1,&r2); 41 scanf("%d %d %d %d",&a.x,&a.y,&b.x,&b.y); 42 double ans=s(r2,r2)-s(r1,r2)-s(r2,r1)+s(r1,r1); 43 printf("Case #%d: %.6lf\n",cas++,ans); 44 } 45 return 0; 46 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」