扫描线的应用。

扫描线就是用数据结构维护一个相对的顺序不变,带修改的东西。

通常只用于一次询问的情况。

抽象的看做一条垂直于x轴直线从左向右扫过去。

这道题目要求求出所有圆的异或并。

所以我们可以求出每一个圆的系数,然后乘上他们的面积。

由于不会出现相交的情况,所以圆弧的相对顺序是不变的。

所以我们用扫描线加入的时候,讨论一下上面的圆弧分别是上下半圆的情况。

然后比较容易的得出结论。

如果是上半圆,这个圆就属于它。

如果是下半弧,那么和它的包含性相同。

接下来找到它的父亲就可以了。

然后用set来维护这条扫描线,比较函数是计算交点的。

然后需要注意一下精度的处理,以及排序的时候第一关键字和第二关键字。

最后计算答案即可。

#include <set>
#include <map>
#include <cmath>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=k;--i)
#define ll long long
#define maxn 200005 ll n,top=0,cal[maxn],T; struct Circle{
ll x,y,r;
Circle (){}
Circle (ll _x,ll _y,ll _r) {x=_x;y=_y;r=_r;}
void read(){scanf("%lld%lld%lld",&x,&y,&r);}
}a[maxn]; struct Events{
ll id,d;
Events(){}
Events(ll _id,ll _d){id=_id;d=_d;}
void print()
{
printf("By Circle %lld Do %lld\n",id,d);
}
}b[maxn<<1]; #define eps 1e-8 int fcmp(double a)
{
return a<-eps?-1:a>eps;
} struct Node{
ll x,y,r,tag,id;
Node () {}
Node (ll _x,ll _y,ll _r,ll _tag,ll _id) {x=_x;y=_y;r=_r;tag=_tag;id=_id;}
void print()
{
printf("At ( %lld, %lld, %lld) Tag %lld\n",x,y,r,tag);
}
bool operator < (const Node & b) const{
double ya,yb;
ya=1.0*r*r-1.0*(T-x)*(T-x);
ya=1.0*y+1.0*tag*sqrt(ya);
yb=1.0*b.r*b.r-1.0*(T-b.x)*(T-b.x);
yb=1.0*b.y+1.0*b.tag*sqrt(yb);
return fcmp(ya-yb)==0?tag<b.tag:fcmp(ya-yb)<0;
}
}; set <Node> s; bool cmpb(Events first,Events second)
{
ll lf=a[first.id].x-a[first.id].r*first.d,ls=a[second.id].x-a[second.id].r*second.d;
return lf==ls?first.d==second.d?a[first.id].y<a[second.id].y:first.d<second.d:lf<ls;
} void Add(int id,int d)
{
Node P;
if (d==1)
{
P=Node(a[id].x,a[id].y,a[id].r,1,id); s.insert(P);
P=Node(a[id].x,a[id].y,a[id].r,-1,id);s.insert(P);
}
else
{
P=Node(a[id].x,a[id].y,a[id].r,1,id); s.erase(P);
P=Node(a[id].x,a[id].y,a[id].r,-1,id);s.erase(P);
}
} ll query(ll x,ll y)
{
T=x;
Node now=Node(x,y,0,1,1);
Node pre=(*(s.upper_bound(now)));
if (pre.tag==1)
return -cal[pre.id];
else
return cal[pre.id];
} int main()
{
scanf("%lld",&n);
F(i,1,n) a[i].read(); a[++n]=Circle(0,0,3e8);
F(i,1,n) b[++top]=Events(i,1),b[++top]=Events(i,-1);
sort(b+1,b+top+1,cmpb);
cal[n]=-1;Add(n,1);
F(i,2,top-1)
{
if (b[i].d==1) cal[b[i].id]=query(a[b[i].id].x-a[b[i].id].r,a[b[i].id].y);
Add(b[i].id,b[i].d);
}
Add(n,-1);
ll ans=0;
F(i,1,n-1) ans+=cal[i]*a[i].r*a[i].r;
printf("%lld\n",ans);
}

BZOJ 4561 [JLoi2016]圆的异或并 ——扫描线的更多相关文章

  1. BZOJ 4561: [JLoi2016]圆的异或并 扫描线 + set

    看题解看了半天...... Code: #include<bits/stdc++.h> #define maxn 200010 #define ll long long using nam ...

  2. bzoj 4561: [JLoi2016]圆的异或并

    Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个 ...

  3. 【BZOJ4561】[JLoi2016]圆的异或并 扫描线

    [BZOJ4561][JLoi2016]圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一 ...

  4. 【BZOJ】4561: [JLoi2016]圆的异或并

    题解 我们把圆拆成两个圆弧,按照圆弧的左右端点排序来增加和删除 那么我们把圆弧按照纵坐标排序,一定是两两不相交的 我们新加入一个圆的时候,找上圆弧的前驱,如果前驱是一个上圆弧,那么这个上圆弧所在的圆就 ...

  5. [BZOJ4561][JLOI2016]圆的异或并(扫描线)

    考虑任何一条垂直于x轴的直线,由于圆不交,所以这条直线上的圆弧构成形似括号序列的样子,且直线移动时圆之间的相对位置不变. 将每个圆拆成两边,左端加右端删.每次加圆时考虑它外面最内层的括号属于谁.用se ...

  6. bzoj4561: [JLoi2016]圆的异或并 圆的扫描线

    地址:http://www.lydsy.com/JudgeOnline/problem.php?id=4561 题目: 4561: [JLoi2016]圆的异或并 Time Limit: 30 Sec ...

  7. BZOJ4561 JLoi2016 圆的异或并 【扫描线】【set】*

    BZOJ4561 JLoi2016 圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一片区 ...

  8. bzoj4561: [JLoi2016]圆的异或并

    Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个 ...

  9. [JLOI2016]圆的异或并

    Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个圆 ...

随机推荐

  1. red hat的防火墙怎么关闭

    查看是否开启: service iptables status 关闭方法: service iptables stop 永远关闭: Ntsysv 把iptables前的*号去掉. 查看SELinux状 ...

  2. Windows服务调试

    Windows 服务(附服务开发辅助工具) 转: http://www.cnblogs.com/BoyXiao/archive/2011/08/07/2130208.html 近来在 Windows ...

  3. Jmeter压力测试工具基本使用

    转:https://blog.csdn.net/envyfan/article/details/42715779

  4. 操作系统(6)_虚拟存储管理_李善平ppt

    image含各种段. 有些不需要的页可能永远不需要装入内存,可能只有百分之70-80是异常情况采用的,这种代码就可以放入硬盘. 抖动实际就是进程数太多导致内存不够用造成的. 页面换入换出在内存和磁盘之 ...

  5. HTML复选框checkbox默认样式修改

    此方法可以将复选框的默认样式替换成任意样式.如图: 未选择: 选择时: 思路:将复选框隐藏,利用lebal元素的焦点传递特性,用lebal的样式替代复选框. 代码如下: <!DOCTYPE ht ...

  6. SAP系统管理中常见问题解答(转载)

    1.如何查看SAP系统的位数? system——status看 Platform ID Platform 32-bit 64-bit --------------------------------- ...

  7. B1066 图像过滤 (15分)

    B1066 图像过滤 (15分) 图像过滤是把图像中不重要的像素都染成背景色,使得重要部分被凸显出来.现给定一幅黑白图像,要求你将灰度值位于某指定区间内的所有像素颜色都用一种指定的颜色替换. 输入格式 ...

  8. 动态规划:HDU-1398-Square Coins(母函数模板)

    解题心得: 1.其实此题有两种做法,动态规划,母函数.个人更喜欢使用动态规划来做,也可以直接套母函数的模板 Square Coins Time Limit: 2000/1000 MS (Java/Ot ...

  9. Word 2013发布博客测试

    Hello world ! I am from word2013! 测试修改 这里添加一行文字.   参考 1在 Word 中建立博客的相关帮助 2使用Word2013发布随笔到博客园 PS: 参考2 ...

  10. Maven 用Eclipse创建web项目后报错的解决方式

    1.maven中创建web项目后jsp可能会报错,因为其没有相关的依赖(包),和自带的动态网页项目创建不一样.所以在配置文件中要添加相关的依赖,比如servlet的 2.项目右键-maven-upda ...