n^2枚举圆盘,用两圆圆心的向量的极角+余弦定理求某个圆覆盖了该圆的哪一段区间(用弧度表示),最后求个区间并。

注意……精度……最好再累计区间的时候,把每个区间的长度减去EPS,防止最后覆盖的总区间超过2PI一点点,使答案为负。

#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
#define EPS 0.000000001
#define INF 1000000.0
int n;
const double PI=acos(-1.0);
double rs[1001],xs[1001],ys[1001],ans;
struct Seg
{
double l,r;
Seg(){}
Seg(const double &L,const double &R){l=L; r=R;}
}q[10001];
bool cmp(const Seg &a,const Seg &b)
{
return fabs(a.l-b.l)<EPS ? a.r<b.r : a.l<b.l;
}
double sqr(const double &x)
{
return x*x;
}
double dis(double x1,double y1,double x2,double y2)
{
return sqrt(sqr(x1-x2)+sqr(y1-y2));
}
int main()
{
// freopen("bzoj1043.in","r",stdin);
scanf("%d",&n);
for(int i=1;i<=n;++i)
scanf("%lf%lf%lf",&rs[i],&xs[i],&ys[i]);
for(int i=1;i<=n;++i)
{
int e=0;
double Lef=2.0*PI;
for(int j=i+1;j<=n;++j)
{
double d=dis(xs[i],ys[i],xs[j],ys[j]);
if(d+rs[i]-rs[j]<EPS)
{
Lef=0.0;
break;
}
else if(d+rs[j]-rs[i]<EPS || rs[i]+rs[j]-d<-EPS)
continue;
// double see=(sqr(d)+sqr(rs[i])-sqr(rs[j]))*0.5/d/rs[i];
double jiao2=acos((sqr(d)+sqr(rs[i])-sqr(rs[j]))*0.5/d/rs[i]);
double jiao1=atan2(ys[j]-ys[i],xs[j]-xs[i]);
if(jiao1<-EPS)
jiao1+=(2.0*PI);
if(jiao1-jiao2<-EPS)
{
q[++e]=Seg(0.0,jiao1+jiao2);
q[++e]=Seg(jiao1-jiao2+2.0*PI,2.0*PI);
}
else if(jiao1+jiao2-2.0*PI>EPS)
{
q[++e]=Seg(jiao1-jiao2,2.0*PI);
q[++e]=Seg(0.0,jiao1+jiao2-2.0*PI);
}
else
q[++e]=Seg(jiao1-jiao2,jiao1+jiao2);
}
// for(int j=e;j;--j)
// {
// bool fl=0;
// for(int k=j-1;k;--k)
// if(!(q[j].l-q[k].r>EPS||q[k].l-q[j].r>EPS))
// {
// q[k].l=min(q[j].l,q[k].l);
// q[k].r=max(q[j].r,q[k].r);
// fl=1;
// break;
// }
// if(!fl)
// Lef-=(q[j].r-q[j].l);
// }
Seg now=Seg(INF,INF);
sort(q+1,q+e+1,cmp);
for(int j=1;j<=e;++j)
if(j==e || q[j+1].l-q[j].l>EPS)
{
if(fabs(now.l-INF)<EPS) now=q[j];
else
{
if(q[j].l-now.r<EPS) now.r=max(now.r,q[j].r);
else
{
Lef-=(now.r-now.l);
now=q[j];
}
}
}
if(fabs(now.l-INF)>=EPS)
Lef-=(now.r-now.l);
if(Lef>EPS)
ans+=(Lef*rs[i]);
}
printf("%.3lf\n",ans);
return 0;
}

【计算几何】bzoj1043 [HAOI2008]下落的圆盘的更多相关文章

  1. bzoj1043[HAOI2008]下落的圆盘 计算几何

    1043: [HAOI2008]下落的圆盘 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1598  Solved: 676[Submit][Stat ...

  2. bzoj1043 [HAOI2008]下落的圆盘

    Description 有n个圆盘从天而降,后面落下的可以盖住前面的.求最后形成的封闭区域的周长.看下面这副图, 所有的红色线条的总长度即为所求. Input 第一行为1个整数n,N<=1000 ...

  3. BZOJ-1043 [HAOI2008]下落的圆盘

    几何题... 先把所有圆储存起来,然后对于每个圆我们求得之后放下的圆挡住了的部分,求个并集,并把没被挡到的周长加进答案. #include <cstdlib> #include <c ...

  4. 【BZOJ1043】[HAOI2008]下落的圆盘 几何

    [BZOJ1043][HAOI2008]下落的圆盘 Description 有n个圆盘从天而降,后面落下的可以盖住前面的.求最后形成的封闭区域的周长.看下面这副图, 所有的红色线条的总长度即为所求.  ...

  5. 【bzoj1043】下落的圆盘

    [bzoj1043]下落的圆盘 题意 有n个圆盘从天而降,后面落下的可以盖住前面的.求最后形成的封闭区域的周长.看下面这副图, 所有的红色线条的总长度即为所求. \(1\leq n\leq 1000\ ...

  6. 【BZOJ1043】下落的圆盘 [计算几何]

    下落的圆盘 Time Limit: 10 Sec  Memory Limit: 162 MB[Submit][Status][Discuss] Description 有n个圆盘从天而降,后面落下的可 ...

  7. luogu P2510 [HAOI2008]下落的圆盘

    LINK:下落的圆盘 计算几何.n个圆在平面上编号大的圆将编号小的圆覆盖求最后所有没有被覆盖的圆的边缘的总长度. 在做这道题之前有几个前置知识. 极坐标系:在平面内 由极点 极轴 和 极径组成的坐标系 ...

  8. 【bzoj1043】[HAOI2008]下落的圆盘 计算几何

    题目描述 有n个圆盘从天而降,后面落下的可以盖住前面的.求最后形成的封闭区域的周长.看下面这副图, 所有的红色线条的总长度即为所求. 输入 第一行为1个整数n,N<=1000接下来n行每行3个实 ...

  9. BZOJ 1043 HAOI2008 下落的圆盘 计算几何

    题目大意:n个圆盘依次下落.求终于能看到的轮廓线面积 円盘反对! 让我们一起团结起来! 赶走円盘! 咳咳.非常神的一道题 今天去看了题解和白书才搞出来-- 首先我们倒着做 对于每一个圆盘处理出在它之后 ...

随机推荐

  1. 在gitlab上setup CI

    安装gitlab runner docker pull gitlab/gitlab-runner 启动gitlab runner docker run -d --name gitlab-runner ...

  2. BZOJ2038: [2009国家集训队]小Z的袜子(hose)

    Time Limit: 20 Sec  Memory Limit: 259 MB Description 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天, ...

  3. shell编程学习

    1.项目中用到Linux的crontrab Linux下的定时执行主要是使用crontab文件中加入定制计划来执行,但是也不是非常复杂,基本上用过一遍就能记住了,关键是要记住/var/spool/cr ...

  4. maven配置之setting配置

    <!--声明语句--> <?xml version="1.0" encoding="UTF-8"?> <settings xmln ...

  5. NetBios 的结构体详解

    [NetBios 的结构体详解] NetBIOS是早期的局域网传输协议. 1.结构体. 2.命令 NetBIOS命令的使用方式有两种,即等待和非等待(或称为同步与异步)方式. 如果命令码的高阶位是0时 ...

  6. 《西科软件》一个高级PHP工程师所应该具备的

    初次接触PHP,就为他的美所折服,于是一发不可收拾.很多面试,很多人员能力要求都有"PHP高级工程师的字眼",如果您真心喜欢PHP,并且您刚起步,那么我简单说说一个PHP高级工程师 ...

  7. HFSS设计导入AD中

    具体过程有些繁琐,录制了一个视频放在百度网盘了.亲测有效. 网盘地址:http://pan.baidu.com/s/1gfIBhC3 密码:ayoa

  8. 利用Unity制作“表”

    一枚小菜鸟   目前没发现在Unity有其他路径制作类似于c# WinForm中的表:但是利用Unity自带的UGUI,制作了一张"伪表",具体方案如下: 效果图如下: 步骤: 1 ...

  9. webpack配置sass模块的加载

    webpack管理的项目,我们希望用sass定义样式,为了正常编译,需要做如下配置.这里不讲webpack的入门,入门的文章,我推荐这篇<webpack入门>. 为了使用sass,我们需要 ...

  10. JS编码解码

    一.定义和用法 encodeURI() 函数可把字符串作为 URI 进行编码. 语法 encodeURI(URIstring) 参数 描述 URIstring 必需.一个字符串,含有 URI 或其他要 ...