BZOJ 2626: JZPFAR KDtree + 堆
escription
Input
下面n行,每行两个整数x_i, y_i,表示n个点的坐标。点的标号按照输入顺序,分别为1..n。
下面一行,一个整数m,表示询问个数。
下面m行,每行三个整数px_i, py_i, k_i,表示一个询问。
Output
#include<bits/stdc++.h>
#define maxn 200000
#define inf 1000000000000000
#define mid ((l+r)>>1)
#define rson(x) (t[x].ch[1])
#define lson(x) (t[x].ch[0])
#define ll long long
using namespace std;
void setIO(string s)
{
string in = s + ".in";
freopen(in.c_str(), "r" , stdin);
}
int d, n, m;
struct Node
{
ll dis;
int k;
Node (ll dis = 0, int k = 0) : dis(dis), k(k) {}
bool operator < (Node b) const
{
return dis == b.dis ? b.k > k : b.dis < dis;
}
};
priority_queue <Node> Q;
// return if a is less than b
bool cmp1(Node a, Node b)
{
return a.dis == b.dis ? a.k > b.k : a.dis < b.dis;
}
ll sqr(ll a)
{
return a * a;
}
struct ND
{
int ch[2], id;
ll p[2], minv[2], maxv[2];
}t[maxn],T;
bool cmp(ND a, ND b)
{
return a.p[d] == b.p[d] ? a.p[d ^ 1] < b.p[d ^ 1] : a.p[d] < b.p[d];
}
void pushup(int x, int y)
{
for(int i = 0; i < 2 ; ++i)
{
t[x].minv[i] = min(t[x].minv[i], t[y].minv[i]);
t[x].maxv[i] = max(t[x].maxv[i], t[y].maxv[i]);
}
}
int build(int l, int r, int o)
{
d = o;
nth_element(t + l, t + mid, t + 1 + r, cmp);
for(int i = 0; i < 2 ; ++i)
t[mid].minv[i] = t[mid].maxv[i] = t[mid].p[i];
lson(mid) = rson(mid) = 0;
if(mid > l)
{
lson(mid) = build(l, mid - 1, o ^ 1);
pushup(mid, lson(mid));
}
if(r > mid)
{
rson(mid) = build(mid + 1, r, o ^ 1);
pushup(mid, rson(mid));
}
return mid;
}
ll getmax(int x)
{
ll ans = 0;
for(int i = 0; i < 2 ; ++i)
{
ans += max(sqr(t[x].minv[i] - T.p[i]), sqr(t[x].maxv[i] - T.p[i]));
}
return ans;
}
void query(int x, ll x1, ll y1)
{
ll cur = sqr(t[x].p[0] - x1) + sqr(t[x].p[1] - y1), dl, dr, dn = getmax(x);
if(dn < Q.top().dis) return;
if(cmp1(Q.top(), Node(cur, t[x].id)))
{
Q.pop();
Q.push(Node(cur, t[x].id));
}
dl = lson(x) ? getmax(lson(x)) : -inf;
dr = rson(x) ? getmax(rson(x)) : -inf;
if(dl > dr)
{
if(dl >= Q.top().dis) query(lson(x), x1, y1);
if(dr >= Q.top().dis) query(rson(x), x1, y1);
}
else
{
if(dr >= Q.top().dis) query(rson(x), x1, y1);
if(dl >= Q.top().dis) query(lson(x), x1, y1);
}
}
int main()
{
int i, j, k, root;
ll x, y;
// setIO("input");
scanf("%d",&n);
for(i = 1; i <= n ; ++i) scanf("%lld%lld",&t[i].p[0],&t[i].p[1]), t[i].id = i;
root = build(1, n, 0);
scanf("%d",&m);
while(m --)
{
scanf("%lld%lld%d",&x,&y,&k);
while(!Q.empty()) Q.pop();
for(i = 1; i <= k ; ++i) Q.push(Node(-2333, -1));
T.p[0] = x, T.p[1] = y;
query(root, x, y);
printf("%d\n",Q.top().k);
}
return 0;
}
BZOJ 2626: JZPFAR KDtree + 堆的更多相关文章
- BZOJ 2626 JZPFAR(KD-tree)
		题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2626 题意:平面上有n个点.现在有m次询问,每次给定一个点(px, py)和一个整数k, ... 
- bzoj 2626: JZPFAR【KD-tree】
		和3053差不多,把pair first做成负数就可以用大根堆维护了 注意:要开long long:比较的时候因为编号也占权重所以要比较pair:编号不是mid!不是mid!是初始输入的那个编号!搞混 ... 
- 【BZOJ2626】JZPFAR kd-tree+堆
		[BZOJ2626]JZPFAR Description 平面上有n个点.现在有m次询问,每次给定一个点(px, py)和一个整数k,输出n个点中离(px, py)的距离第k大的点的标号.如果有两个( ... 
- bzoj 2626: JZPFAR k-D树
		题目大意: 平面上n个点,每次给出一个点,求这个点的k远点 题解: 什么叫做k远点呢... 1 2 3 4 5中5是第一远,4是第二远... 看来我语文学的不好 那么我们直接上k-D Tree求k邻近 ... 
- BZOJ 2626 & KDtree
		题意: 二维平面n个点 每次给出一个点询问距离第k小的点. SOL: kdtree裸题,抄了一发别人的模板...二维割起来还是非常显然的.膜rzz的论文. 不多说了吧.... Code: /*==== ... 
- 【24.91】【Tsinsen 1302】&【BZOJ 2626】JZPFAR
		时间限制:5.0s 内存限制:256.0MB 总提交次数:547 AC次数:137 平均分:40.31 将本题分享到: 查看未格式化的试题 提交 试题讨论 试题来 ... 
- 【BZOJ-4520】K远点对    KD-Tree + 堆
		4520: [Cqoi2016]K远点对 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 490 Solved: 237[Submit][Status ... 
- BZOJ4520 CQOI2016K远点对(KD-Tree+堆)
		堆维护第k大,每个点KD-Tree上A*式查询较远点,跑得飞快,复杂度玄学. #include<iostream> #include<cstdio> #include<c ... 
- 【BZOJ4520】[Cqoi2016]K远点对 kd-tree+堆
		[BZOJ4520][Cqoi2016]K远点对 Description 已知平面内 N 个点的坐标,求欧氏距离下的第 K 远点对. Input 输入文件第一行为用空格隔开的两个整数 N, K.接下来 ... 
随机推荐
- HDOJ--1285--确定比赛名次
			确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ... 
- (WIP) DPDK理论学习(by quqi99)
			作者:张华 发表于:2016-04-22版权声明:能够随意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明 ( http://blog.csdn.net/quqi99 ) 组成模 ... 
- LeetCode 720. Longest Word in Dictionary (字典里最长的单词)
			Given a list of strings words representing an English Dictionary, find the longest word in words tha ... 
- linux RHEL 修改hostname 不需要重启机器
			1. 修改/etc/sysconfig/network 中的hostname HOSTNAME=newhostname 运行命令起作用: /etc/rc.d/rc.sysinit 2. 修改/ect/ ... 
- CMDBuild安装及webservice接口的获取
			近期项目组之前一直使用的OneCMDB出现了问题,在增删改数据时异常的慢.于是考虑能否够优化OneCMDB.由于本人水平有限,对OneCMDB进行代码级别的优化临时还有点难度.于是就对现有的其它开源C ... 
- SQL分离附加数据库
			转自:http://www.jb51.net/article/36624.htm 
- Coursera Algorithms week3 快速排序 练习测验: Selection in two sorted arrays(从两个有序数组中寻找第K大元素)
			题目原文 Selection in two sorted arrays. Given two sorted arrays a[] and b[], of sizes n1 and n2, respec ... 
- codevs1690 开关灯(线段树)
			1690 开关灯 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description YYX家门前的街上有N(2< ... 
- [Swift通天遁地]二、表格表单-(2)创建右侧带有索引的UITableView(表单视图)
			★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ... 
- 网络简要<入门篇>
			OSI七层 网络的含义:两个不在同一地理位置的主机(终端),通过传输介质和通信协议,实现通信和资源共享. 网络四要素:终端,传输介质 ,通信协议,资源 网络分类: 以范围分类:LAN网(局域网,以太网 ... 
