【LOJ】#2586. 「APIO2018」选圆圈
题解
不旋转坐标系,TLE,旋转坐标系,最慢一个点0.5s……maya,出题人数据水平很高了……
好吧,如果你不旋转坐标系,写一个正确性和复杂度未知的K - D树,没有优化,你可以得到87分的好成绩
但是你就是傻逼,你就是写不出来,能有什么办法,APIO Ag滚粗了呗= =
这道题看起来需要用什么东西维护一下平面,查找给定一个圆这个平面内多少个圆和它有交集,可以K - D树
我们考虑维护一个集合里的圆覆盖的矩形,就是最大的横纵坐标和最小的横纵坐标,查询的时候只要看看和当前圆横纵坐标是不是有交集,有交集就查,同时维护一下这棵树里还有没有圆没有被删除
当然复杂度可能会很劣……但是不劣的算法也不会,你就写了,写完之后87
哦87挺好的哦,然而不是考场上我想写写100分啊,看了大家似乎旋转了坐标系,然后我也转了,咦我怎么WA了……把eps调小一点就过了
为什么我那么菜啊= =
代码
#include <iostream>
#include <cstdio>
#include <vector>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <map>
//#define ivorysi
#define pb push_back
#define space putchar(' ')
#define enter putchar('\n')
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define mo 974711
#define MAXN 300005
#define eps 1e-3
#define RG register
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
res = 0;char c = getchar();T f = 1;
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {putchar('-');x = -x;}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
struct Point {
db x,y;
Point() {}
Point(db _x,db _y) {
x = _x;y = _y;
}
};
struct Circle {
Point a;db R;int id;
}cir[MAXN],C[MAXN];
db o(db x) {
return x * x;
}
db dist(Point a,Point b) {
return o(a.x - b.x) + o(a.y - b.y);
}
bool cmpc(Circle s,Circle t) {
return s.R > t.R || (s.R == t.R && s.id < t.id);
}
const db alpha = acos(-1.0) / 5;
int tr[MAXN * 4],pos[MAXN],N,D[MAXN],tot,a[MAXN];
bool vis[MAXN],dimension;
struct node {
Circle cir;Point r1,r2;
node *lc,*rc;int siz;
void update_siz() {
siz = 0;
if(!vis[cir.id]) siz = 1;
siz += lc->siz;
siz += rc->siz;
}
void update() {
r1.x = cir.a.x - cir.R;r1.y = cir.a.y - cir.R;
r2.x = cir.a.x + cir.R;r2.y = cir.a.y + cir.R;
r1.x = min(r1.x,min(lc->r1.x,rc->r1.x));
r1.y = min(r1.y,min(lc->r1.y,rc->r1.y));
r2.x = max(r2.x,max(lc->r2.x,rc->r2.x));
r2.y = max(r2.y,max(lc->r2.y,rc->r2.y));
}
}*rt,*null;
bool cmp(Circle s,Circle t) {
if(dimension) return s.a.x + s.R + eps < t.a.x + t.R;
else return s.a.y + s.R + eps < t.a.y + t.R;
}
node* build(int l,int r,bool d) {
if(l > r) return null;
node *res = new node;
int mid = (l + r) >> 1;
dimension = d;
nth_element(C + l,C + mid,C + r + 1,cmp);
res->cir = C[mid];
res->lc = build(l,mid - 1,d ^ 1);res->rc = build(mid + 1,r,d ^ 1);
res->update();res->update_siz();
return res;
}
bool fit(node *u,Circle S) {
db l[2] = {u->r1.x,S.a.x - S.R};
db r[2] = {u->r2.x,S.a.x + S.R};
if(l[0] > l[1]) swap(l[0],l[1]),swap(r[0],r[1]);
if(l[1] > r[0]) return 0;
l[0] = u->r1.y,l[1] = S.a.y - S.R;
r[0] = u->r2.y,r[1] = S.a.y + S.R;
if(l[0] > l[1]) swap(l[0],l[1]),swap(r[0],r[1]);
if(l[1] > r[0]) return 0;
return 1;
}
void Query(node *u,Circle S) {
if(!u->siz) return;
if(!vis[u->cir.id]) {
if(dist(u->cir.a,S.a) <= o(u->cir.R + S.R) + eps) {
vis[u->cir.id] = 1;
a[u->cir.id] = S.id;
--tot;
}
}
if(fit(u->lc,S)) Query(u->lc,S);
if(fit(u->rc,S)) Query(u->rc,S);
u->update_siz();
}
void Init() {
null = new node;
null->siz = 0;
null->r1 = Point(2000000000,2000000000);
null->r2 = Point(-2000000000,-2000000000);
read(N);
db x,y,r;
for(int i = 1 ; i <= N ; ++i) {
scanf("%lf%lf%lf",&x,&y,&r);
cir[i] = (Circle){Point(x * cos(alpha) - y * sin(alpha),x * sin(alpha) + y * cos(alpha)),r,i};
C[i] = cir[i];
}
sort(cir + 1,cir + N + 1,cmpc);
rt = build(1,N,0);
}
void Solve() {
for(int i = 1 ; i <= N ; ++i) {
if(!a[cir[i].id]) Query(rt,cir[i]);
}
for(int i = 1 ; i <= N ; ++i) {
out(a[i]);if(i == N) enter;else space;
}
//out(clock());enter;
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Init();
Solve();
return 0;
}
【LOJ】#2586. 「APIO2018」选圆圈的更多相关文章
- LOJ 2586 「APIO2018」选圆圈——KD树
题目:https://loj.ac/problem/2586 只会 19 分的暴力. y 都相等,仍然按直径从大到小做.如果当前圆没有被删除,那么用线段树把 [ x-r , x+r ] 都打上它的标记 ...
- 「APIO2018」选圆圈
传送门 Description 有\(n\)个圆,每次找到这些圆中半径最大中的编号最小的圆,删除ta及与其有交集的所有圆. 对于每个圆,求出它是被哪一个圆删除的. Solution K-D Tree ...
- LOJ #2585. 「APIO2018」新家
#2585. 「APIO2018」新家 https://loj.ac/problem/2585 分析: 线段树+二分. 首先看怎样数颜色,正常的时候,离线扫一遍右端点,每次只记录最右边的点,然后查询左 ...
- LOJ #2587「APIO2018」铁人两项
是不是$ vector$存图非常慢啊...... 题意:求数对$(x,y,z)$的数量使得存在一条$x$到$z$的路径上经过$y$,要求$x,y,z$两两不同 LOJ #2587 $ Solutio ...
- LOJ 2587 「APIO2018」铁人两项——圆方树
题目:https://loj.ac/problem/2587 先写了 47 分暴力. 对于 n<=50 的部分, n3 枚举三个点,把图的圆方树建出来,合法条件是 c 是 s -> f 路 ...
- LOJ 2585 「APIO2018」新家 ——线段树分治+二分答案
题目:https://loj.ac/problem/2585 算答案的时候要二分! 这样的话,就是对于询问位置 x ,二分出一个最小的 mid 使得 [ x-mid , x+mid ] 里包含所有种类 ...
- 【刷题】LOJ 2587 「APIO2018」铁人两项
题目描述 比特镇的路网由 \(m\) 条双向道路连接的 \(n\) 个交叉路口组成. 最近,比特镇获得了一场铁人两项锦标赛的主办权.这场比赛共有两段赛程:选手先完成一段长跑赛程,然后骑自行车完成第二段 ...
- loj#2016. 「SCOI2016」美味
题目链接 loj#2016. 「SCOI2016」美味 题解 对于不带x的怎么做....可持久化trie树 对于带x,和trie树一样贪心 对于答案的二进制位,从高往低位贪心, 二进制可以表示所有的数 ...
- Loj #3102. 「JSOI2019」神经网络
Loj #3102. 「JSOI2019」神经网络 题目背景 火星探险队发现,火星人的思维方式与人类非常不同,是因为他们拥有与人类很不一样的神经网络结构.为了更好地理解火星人的行为模式,JYY 对小镇 ...
随机推荐
- 洛谷P1029 最大公约数和最小公倍数问题
题目描述 输入二个正整数x0,y0(2<=x0<100000,2<=y0<=1000000),求出满足下列条件的P,Q的个数 条件: 1.P,Q是正整数 2.要求P,Q以x0为 ...
- SpringBoot ( 八 ) :RabbitMQ 详解
原文出处: 纯洁的微笑 RabbitMQ 即一个消息队列,主要是用来实现应用程序的异步和解耦,同时也能起到消息缓冲,消息分发的作用. 消息中间件在互联网公司的使用中越来越多,刚才还看到新闻阿里将Roc ...
- TCP协议基础知识及wireshark抓包分析实战
TCP相关知识 应swoole长连接开发调研相关TCP知识并记录. 数据封包流程 如图,如果我需要发送一条数据给用户,实际的大小肯定是大于你发送的大小,在各个数据层都进行了数据的封包,以便你的数据能完 ...
- 5W次单点修改,求最长的连续上升子序列 HDU 3308
题目大意:给你n个数,m个操作. 有两种操作: 1.U x y 将数组第x位变为y 2. Q x y 问数组第x位到第y位连续最长子序列的长度. 对于每次询问,输出连续最长子序列的长度 思路:用线段树 ...
- 自己封装的ASP.NET的MYSQL的数据库操作类
/** * 作者:牛腩 * 创建时间:2010年3月7日17时35分 * 类说明:对MYSQL数据库的操作类 */ using System; using System.Data; using MyS ...
- [Mac]一些命令技巧
Git相关 mac下git默认不区分大小写,通过下面脚本可以改变 #!/bin/bash # 让git区分大小写 cd 'path-of-project' git config core.ignore ...
- 【POJ】2142 The Balance 数论(扩展欧几里得算法)
[题意]给定a,b,c,在天平左边放置若干重量a的砝码,在天平右边放置若干重量b的砝码,使得天平两端砝码差为c.设放置x个A砝码和y个B砝码,求x+y的最小值. [算法]数论(扩展欧几里德算法) [题 ...
- JavaScript事件和方法
单击一个超链接触发事件 1.用a标签的onclick <a href="#" onclick="js代码"> 这种写法呢,存在一种弊端,就是点击后会 ...
- unity3d 资源文件从MAX或者MAYA中导出的注意事项
unity3d 资源文件从MAX或者MAYA中导出的注意事项 1.首先,Unity3d 中,导出带动画的资源有2种导出方式可以选择: 1) 导出资源时,只导出一个文件,保留模型,骨骼和所 ...
- perl6 struct2-045 EXP
测试站点: http://www.yutian.com.cn/index.action http://www.hjxzyzz.com:8088/pfw/login.action 代码如下: use v ...