bzoj4561
扫描线
想法挺妙 搞了很长很长时间。。。
http://www.cppblog.com/superlong/archive/2010/08/06/122427.html
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<ll, int> PII;
const int N = ;
int n;
ll ans, nowx;
int x[N], y[N], r[N], mark[N];
inline ll sqr(int x)
{
return (ll)x * (ll)x;
}
struct data {
int id, w;
data(int id = , int w = ) : id(id), w(w) {}
bool friend operator < (data A, data B)
{
double l1 = (double)y[A.id] + (double)A.w * sqrt(sqr(r[A.id]) - sqr(nowx - x[A.id]));
double l2 = (double)y[B.id] + (double)B.w * sqrt(sqr(r[B.id]) - sqr(nowx - x[B.id]));
return l1 == l2 ? A.w < B.w : l1 < l2;
}
};
vector<PII> v;
set<data> s;
int main()
{
scanf("%d", &n);
for(int i = ; i <= n; ++i)
{
scanf("%d%d%d", &x[i], &y[i], &r[i]);
v.push_back(make_pair((ll)x[i] - (ll)r[i], i));
v.push_back(make_pair((ll)x[i] + (ll)r[i], -i));
}
sort(v.begin(), v.end());
for(int i = ; i < v.size(); ++i)
{
PII t = v[i];
int p = t.second;
nowx = v[i].first;
if(p < )
{
s.erase(data(-p, -));
s.erase(data(-p, ));
}
else
{
set<data> :: iterator it = s.upper_bound(data(p, ));
if(it == s.end())
mark[p] = ;
else if(it -> w == )
mark[p] = -mark[it -> id];
else mark[p] = mark[it -> id];
s.insert(data(p, -));
s.insert(data(p, ));
}
}
for(int i = ; i <= n; ++i)
ans += (ll)mark[i] * (ll)r[i] * (ll)r[i];
printf("%lld\n", ans);
return ;
}
bzoj4561的更多相关文章
- BZOJ4561 JLOI2016圆的异或并(扫描线+平衡树)
		考虑一条扫描线从左到右扫过这些圆.观察某一时刻直线与这些圆的交点,可以发现构成一个类似括号序列的东西,括号的包含关系与圆的包含关系是相同的.并且当扫描线逐渐移动时,括号间的相对顺序不变.于是考虑用se ... 
- [BZOJ4561][JLOI2016]圆的异或并(扫描线)
		考虑任何一条垂直于x轴的直线,由于圆不交,所以这条直线上的圆弧构成形似括号序列的样子,且直线移动时圆之间的相对位置不变. 将每个圆拆成两边,左端加右端删.每次加圆时考虑它外面最内层的括号属于谁.用se ... 
- BZOJ4561 JLoi2016 圆的异或并 【扫描线】【set】*
		BZOJ4561 JLoi2016 圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一片区 ... 
- 【BZOJ4561】[JLoi2016]圆的异或并 扫描线
		[BZOJ4561][JLoi2016]圆的异或并 Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面积并.异或面积并为:当一 ... 
- 【BZOJ-4561】圆的异或并        set + 扫描线
		4561: [JLoi2016]圆的异或并 Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 254 Solved: 118[Submit][Statu ... 
- bzoj4561: [JLoi2016]圆的异或并
		Description 在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个 ... 
- bzoj4561: [JLoi2016]圆的异或并 圆的扫描线
		地址:http://www.lydsy.com/JudgeOnline/problem.php?id=4561 题目: 4561: [JLoi2016]圆的异或并 Time Limit: 30 Sec ... 
- BZOJ4561:圆的异或并(扫描线+set||splay||线段树)
		在平面直角坐标系中给定N个圆.已知这些圆两两没有交点,即两圆的关系只存在相离和包含.求这些圆的异或面 积并.异或面积并为:当一片区域在奇数个圆内则计算其面积,当一片区域在偶数个圆内则不考虑. I ... 
- BZOJ4561: [JLoi2016]圆的异或并  计算几何+treap
		因为本题保证两圆之间只有相包含或相离(不用担心两圆重合 因为我没有RE) 所以每个圆之间的相对位置是确定的 也就是可以按极角排序的, 所以可以按横坐标排序后 扫描同时用treap维护加圆删圆(即遇到 ... 
随机推荐
- 继 S-HR之代码创建临时表并插入数据 完整功能之员工职业信息变更报表
			目的示例1: 制作员工职业信息报表[S-HR系统的报表其实就是列表o.0,醉了] EcirrWithPP.js shr.defineClass("shr.custom.EcirrWithPP ... 
- HTML元素以及HTML元素的分类
			HTML元素以及HTML元素的分类 html标签又叫做html元素,它分为块级元素和内联元素(也可以叫做行内元素),都是html规范中的概念 块级元素 含义:块级元素是指本身属性为display:bl ... 
- HDU - 4803 - Poor Warehouse Keeper (思维)
			题意: 给出x,y两个值分别代表x个物品,总价为y 有两种变化: 1.使总价+1,数量不变 2.数量+1,总价跟着变化 (y = y + y / x) 思路: 给出目标x,y,计算最少变化次使数量变化 ... 
- 窥探原理:实现一个简单的前端代码打包器 Roid
			roid roid 是一个极其简单的打包软件,使用 node.js 开发而成,看完本文,你可以实现一个非常简单的,但是又有实际用途的前端代码打包工具. 如果不想看教程,直接看代码的(全部注释):点击地 ... 
- power coefficient calculation -- post processing
			input: unscaled moment of one bladeoutput: power coefficient of a 3-blades wind/tidal turbine matlab ... 
- 洛谷 2484 [SDOI2011]打地鼠
			[题解] n^6的做法很好想,然而这样复杂度不对.. 然后我们可以发现R和C可以分开求,这样复杂度降到了n^4. 使用树状数组可以把复杂度降到n^3logn,可以顺利通过. #include<c ... 
- type="application/javascript"
			type="application/javascript" html script 标签中 type有如下这些值,请问分别是什么意思,在什么情况下使用? type="te ... 
- JWT & HMAC-SHA256
			JWT JSON Web Tokens https://jwt.io/ https://en.wikipedia.org/wiki/JSON_Web_Token#Structure HMACSHA25 ... 
- [luoguP1280] 尼克的任务(DP)
			传送门 原本想着 f[i] 表示前 i 个任务的最优答案,但是不好转移 看了题解后,发现是 f[i] 表示前 i 分钟的最优解,看来还是不能死脑筋,思维得活跃,一个思路行不通就换一个思路. 把 f 数 ... 
- uestc   1904
			#include<stdio.h> #define N 1010 int min[N]; int main() { int t,n,p,ti,first,end,num,i,j,max, ... 
