BZOJ 4561 [JLoi2016]圆的异或并 ——扫描线
扫描线的应用。
扫描线就是用数据结构维护一个相对的顺序不变,带修改的东西。
通常只用于一次询问的情况。
抽象的看做一条垂直于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]圆的异或并 ——扫描线的更多相关文章
- BZOJ 4561: [JLoi2016]圆的异或并 扫描线 + set
看题解看了半天...... Code: #include<bits/stdc++.h> #define maxn 200010 #define ll long long using nam ...
- bzoj 4561: [JLoi2016]圆的异或并
Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个 ...
- 【BZOJ4561】[JLoi2016]圆的异或并 扫描线
[BZOJ4561][JLoi2016]圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一 ...
- 【BZOJ】4561: [JLoi2016]圆的异或并
题解 我们把圆拆成两个圆弧,按照圆弧的左右端点排序来增加和删除 那么我们把圆弧按照纵坐标排序,一定是两两不相交的 我们新加入一个圆的时候,找上圆弧的前驱,如果前驱是一个上圆弧,那么这个上圆弧所在的圆就 ...
- [BZOJ4561][JLOI2016]圆的异或并(扫描线)
考虑任何一条垂直于x轴的直线,由于圆不交,所以这条直线上的圆弧构成形似括号序列的样子,且直线移动时圆之间的相对位置不变. 将每个圆拆成两边,左端加右端删.每次加圆时考虑它外面最内层的括号属于谁.用se ...
- bzoj4561: [JLoi2016]圆的异或并 圆的扫描线
地址:http://www.lydsy.com/JudgeOnline/problem.php?id=4561 题目: 4561: [JLoi2016]圆的异或并 Time Limit: 30 Sec ...
- BZOJ4561 JLoi2016 圆的异或并 【扫描线】【set】*
BZOJ4561 JLoi2016 圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一片区 ...
- bzoj4561: [JLoi2016]圆的异或并
Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个 ...
- [JLOI2016]圆的异或并
Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个圆 ...
随机推荐
- SOA体系-三大核心部件
1.ESB(Enterprise Service Bus)企业服务总线.ESB是传统中间件技术与XML.Web服务等技术结合的产物.ESB提供了网络中最基本的连接中枢,是构筑企业神经系统的必要元素.从 ...
- python_26_dictionary
#key-value 字典无下标 所以乱序,key值尽量不要取中文 info={ 'stu1101':'Liu Guannan', 'stu1102':'Wang Ruipu', 'stu1103': ...
- advanced regression to predict housing prices
https://docs.google.com/presentation/d/e/2PACX-1vQGlXP6QZH0ATzXYwnrXinJcCn00fxCOoEczPAXU-n3hAPLUfMfi ...
- BZOJ1576: [Usaco2009 Jan]安全路经Travel(最短路 并查集)
题意 给你一张无向图,保证从1号点到每个点的最短路唯一.对于每个点求出删掉号点到它的最短路上的最后一条边(就是这条路径上与他自己相连的那条边)后1号点到它的最短路的长度 Sol emmm,考场上想了个 ...
- BZOJ2023: [Usaco2005 Nov]Ant Counting 数蚂蚁(dp)
题意 题目描述的很清楚... 有一天,贝茜无聊地坐在蚂蚁洞前看蚂蚁们进进出出地搬运食物.很快贝茜发现有些蚂蚁长得几乎一模一样,于是她认为那些蚂蚁是兄弟,也就是说它们是同一个家族里的成员.她也发现整个 ...
- MySQL - RIGHT JOIN
RIGHT JOIN 关键字 RIGHT JOIN 关键字会右表 (table_name2) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行. RIGHT JOIN 关键字语 ...
- Nuxt.js 基础入门教程
原文链接 Vue 开发一个单页面应用,相信很多前端工程师都已经学会了,但是单页面应用有一个致命的缺点,就是 SEO 极不友好.除非,vue 能在服务端渲染(ssr)并直接返回已经渲染好的页面,而并非只 ...
- 设置虚拟机里的Centos7的IP
输入ip查询命名 ip addr 也可以输入 ifconfig查看ip,但此命令会出现3个条目,centos的ip地址是ens33条目中的inet值. 发现 ens33 没有 inet 这个属性,那 ...
- 修改python新建文件时的模板
- 数据库sql中distinct用法注意事项
在写sql中去重复等操作,需要用到distinct. 在使用distinct的时候要注意,尤其是在有行列转换的时候.要把sql运行出来看看是不是与你想要的结果一样. 通过自己试验,distinct有从 ...