[国家集训队2012]JZPFAR
[国家集训队2012]JZPFAR
题目
平面上有n个点。现在有m次询问,每次给定一个点(px, py)和一个整数k,输出n个点中离(px, py)的距离第k大的点的标号。如果有两个(或多个)点距离(px, py)相同,那么认为标号较小的点距离较大。
INPUT
第一行,一个整数n,表示点的个数。
下面n行,每行两个整数x_i, y_i,表示n个点的坐标。点的标号按照输入顺序,分别为1..n。
下面一行,一个整数m,表示询问个数。
下面m行,每行三个整数px_i, py_i, k_i,表示一个询问。OUTPUT
m行,每行一个整数,表示相应的询问的答案。
SAMPLE
INPUT
3
0 0
0 1
0 2
3
1 1 2
0 0 3
0 1 1OUTPUT
3
1
1
解题报告
首道K-D树
然而只是照着打了个板子QAQ
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std;
typedef long long L;
const L inf((L)1e16);
int now,n,m,k;
inline int read(){
int sum(),f();
char ch(getchar());
for(;ch<''||ch>'';ch=getchar())
if(ch=='-')
f=-;
for(;ch>=''&&ch<='';sum=sum*+(ch^),ch=getchar());
return sum*f;
}
struct point{
L a[];
inline bool operator<(const point &b)const{
return a[now]<b.a[now]||(a[now]==b.a[now]&&a[now^]<b.a[now^]);
}
L &operator[](int x){
return a[x];
}
}p[],cmp;
struct data{
L dis,id;
inline bool operator<(const data &a)const{
return dis==a.dis?id<a.id:dis>a.dis;
}
};
priority_queue<data>q;
inline L pf(L x){
return x*x;
}
inline L dis(point x,point y){
return pf(x[]-y[])+pf(x[]-y[]);
}
struct node{
node *lch,*rch;
point key;
int mn[],mx[];
node(point &x):key(x),lch(NULL),rch(NULL){
mn[]=mx[]=x[];
mn[]=mx[]=x[];
}
inline void pushup(node *x){
if(x==NULL)
return;
mn[]=min(mn[],x->mn[]),mn[]=min(mn[],x->mn[]);
mx[]=max(mx[],x->mx[]),mx[]=max(mx[],x->mx[]);
}
inline L cal_dis(){
L ret();
ret=max(ret,dis((point){mn[],mn[]},cmp));
ret=max(ret,dis((point){mn[],mx[]},cmp));
ret=max(ret,dis((point){mx[],mn[]},cmp));
ret=max(ret,dis((point){mx[],mx[]},cmp));
return ret;
}
}*root;
inline void build(node *&rt,int l,int r,int d){
if(l>r)
return;
int mid((l+r)>>);
now=d;
nth_element(p+l,p+mid,p+r+);
rt=new node(p[mid]);
build(rt->lch,l,mid-,d^);
build(rt->rch,mid+,r,d^);
rt->pushup(rt->lch);
rt->pushup(rt->rch);
}
inline void query(node *rt){
if(rt==NULL)
return;
if(q.size()==k&&rt->cal_dis()<q.top().dis)
return;
data ret((data){dis(rt->key,cmp),rt->key[]});
if(q.size()<k)
q.push(ret);
else
if(ret<q.top())
q.pop(),q.push(ret);
L dis_l(rt->lch==NULL?inf:rt->lch->cal_dis());
L dis_r(rt->rch==NULL?inf:rt->rch->cal_dis());
if(dis_l>dis_r){
query(rt->lch);
if(dis_r>=q.top().dis||q.size()<k)
query(rt->rch);
}
else{
query(rt->rch);
if(dis_l>=q.top().dis||q.size()<k)
query(rt->lch);
}
}
inline int gg(){
freopen("jzpfar.in","r",stdin);
freopen("jzpfar.out","w",stdout);
n=read();
for(int i=;i<=n;++i)
p[i][]=read(),p[i][]=read(),p[i][]=i;
build(root,,n,);
m=read();
while(m--){
cmp[]=read(),cmp[]=read(),k=read();
while(!q.empty())
q.pop();
query(root);
printf("%d\n",q.top().id);
}
return ;
}
int K(gg());
int main(){;}
[国家集训队2012]JZPFAR的更多相关文章
- [国家集训队2012]middle
http://cogs.pro:8080/cogs/problem/problem.php?pid=1763 二分答案x 把区间内>=x的数设为1,<x的数设为-1 左端点在[a,b]之间 ...
- [国家集训队2012]tree(陈立杰)
[国家集训队2012]tree(陈立杰) 题目 给你一个无向带权连通图,每条边是黑色或白色.让你求一棵最小权的恰好有need条白色边的生成树.题目保证有解. INPUT 第一行V,E,need分别表示 ...
- 数据结构(动态树):[国家集训队2012]tree(伍一鸣)
[问题描述] 一棵n个点的树,每个点的初始权值为1.对于这棵树有q个操作,每个操作为以下四种操作之一: + u v c:将u到v的路径上的点的权值都加上自然数c: - u1 v1 u2 v2:将树中原 ...
- 【国家集训队2012】tree(伍一鸣)
Description 一棵n个点的树,每个点的初始权值为1.对于这棵树有q个操作,每个操作为以下四种操作之一: + u v c:将u到v的路径上的点的权值都加上自然数c: - u1 v1 u2 ...
- [COGS 1799][国家集训队2012]tree(伍一鸣)
Description 一棵n个点的树,每个点的初始权值为1.对于这棵树有q个操作,每个操作为以下四种操作之一: + u v c:将u到v的路径上的点的权值都加上自然数c: - u1 v1 u2 v2 ...
- cogs1799 [国家集训队2012]tree(伍一鸣)
LCT裸题 注意打标记之间的影响就是了 这个膜数不会爆unsigned int #include<cstdio> #include<cstdlib> #include<a ...
- BZOJ2568 [国家集训队2012]比特集合
Description 比特集合是一种抽象数据类型(Abstract Data Type) ,其包含一个集合S,并支持如下几种操作: INS M : 将元素 M 插入到集合S中: DEL M : 将集 ...
- [国家集训队2012]middle(陈立杰)
我是萌萌的传送门 我是另一个萌萌的传送门 脑残错误毁一下午…… 其实题解早就烂大街了,然而很久之前我只知道是二分答案+主席树却想不出来这俩玩意儿怎么一块儿用的……今天又翻了几篇题解才恍然大悟,是把权值 ...
- [国家集训队2012]tree(陈立杰) 题解(二分+最小生成树)
tree 时间限制: 3 Sec 内存限制: 512 MB 题目描述 给你一个无向带权连通图,每条边是黑色或白色.让你求一棵最小权的恰好有need条白色边的生成树. 题目保证有解. 输入 第一行V, ...
随机推荐
- P1606 [USACO07FEB]白银莲花池Lilypad Pond
这个题其实算是个最短路计数,建图的直观思想很简单,但是很显然有一个地方没法处理,就是有的时候通过两条路走到同一个地方的话方案数会计算两次.我们发现加上原有的莲花就很难处理,会计算重复.我们要想办法避免 ...
- MySQL的安装和启动
一.MySQL各类安装方法的比较 在Linux系统下,MySQL有3种主要的安装方式,分别是:RPM安装.二进制安装.源码安装.三种安装方式的优缺点如下表所示: RPM安装 二进制安装 源码安装 ...
- Angular——流程控制指令
基本介绍 (1)ng-repeat,类似于for循环,对数组进行遍历 (2)ng-switch on,ng-switch-when,类似于switch,case 基本使用 ng-repeat < ...
- Angular——数据绑定
基本介绍 angularjs可以实现数据的双向绑定:(1)视图到模型的数据绑定,(2)模型到数据的绑定 基本使用 1.ng-model可以实现视图到模型的数据传输 2.{{name}}可以实现模型到视 ...
- html5——多媒体(四)
全屏兼容 box.requestFullscreen(); box.webkitRequestFullScreen(); box.mozRequestFullScreen(); <!DOCTYP ...
- html5——多列布局
基本概念 1.多列布局类似报纸或杂志中的排版方式,上要用以控制大篇幅文本. 2.跨列属性可以控制横跨列的数量 /*列数*/ -webkit-column-count: ; /*分割线*/ -webki ...
- Python语言之类
1.一个空类 #Filename : emptyclass.py class Empty: pass e = Empty() print( e ) #<__main__.Empty object ...
- 安装nodejs6.9x以后,原来在nodejs4.2.x中运行正常的ionic项目出现问题的解决
安装nodejs6.9x以后,原来在nodejs4.2.x中运行正常的程序出现的问题.看错误信息,由于NodeJs版本升级导致的. 到提示的目录下运行:npm rebuild node-sass -g ...
- UICollectionView(一)基本概念
整体预览 高等级的包含和管理(Top-level containment and management) UICollectionView UICollectionViewController UIC ...
- CorelDRAW快速制作抖音幻影图像效果
本教程讲解非常受欢迎的幻影图像效果(Anaglyph 3d),也叫图像分色立体效果,这其中我们要用到CorelDRAW中的透明度工具. 在开始实施Anaglyph效应之前,应当知道,Anaglyph ...