http://www.lydsy.com/JudgeOnline/problem.php?id=4520 (题目链接)

题意

  求平面内第K远点对的距离。

Solution

  左转题解:jump

细节

  刚开始我还开了两个堆,想想其实是没必要的→_→

  距离什么的开LL

代码

// bzoj4520
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<vector>
#include<cmath>
#include<queue>
#define LL long long
#define inf 1<<30
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std; const int maxn=100010;
int n,m,D,K,rt;
priority_queue<LL,vector<LL>,greater<LL> > q; struct KDtree {
int l,r,v[2],mn[2],mx[2];
friend bool operator < (const KDtree a,const KDtree b) {
return a.v[D]<b.v[D];
}
}tr[maxn],S; void update(int k) {
for (int i=0;i<=1;i++) {
if (tr[k].l) {
tr[k].mn[i]=min(tr[k].mn[i],tr[tr[k].l].mn[i]);
tr[k].mx[i]=max(tr[k].mx[i],tr[tr[k].l].mx[i]);
}
if (tr[k].r) {
tr[k].mn[i]=min(tr[k].mn[i],tr[tr[k].r].mn[i]);
tr[k].mx[i]=max(tr[k].mx[i],tr[tr[k].r].mx[i]);
}
}
}
int build(int l,int r,int p) {
D=p;
int mid=(l+r)>>1;
nth_element(tr+l,tr+mid,tr+r+1);
if (l<mid) tr[mid].l=build(l,mid-1,p^1);
if (r>mid) tr[mid].r=build(mid+1,r,p^1);
update(mid);
return mid;
}
LL dis(LL x1,LL y1,LL x2,LL y2) {
return (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
}
LL eva(int k) {
LL lu=dis(S.v[0],S.v[1],tr[k].mn[0],tr[k].mn[1]);
LL ru=dis(S.v[0],S.v[1],tr[k].mx[0],tr[k].mn[1]);
LL ld=dis(S.v[0],S.v[1],tr[k].mn[0],tr[k].mx[1]);
LL rd=dis(S.v[0],S.v[1],tr[k].mx[0],tr[k].mx[1]);
return max(max(lu,ru),max(ld,rd));
}
void query(int k) {
if (!k) return;
LL d=dis(S.v[0],S.v[1],tr[k].v[0],tr[k].v[1]);
if (q.top()<d) q.pop(),q.push(d);
LL dl=eva(tr[k].l),dr=eva(tr[k].r);
if (dl>dr) {
if (q.top()<dl) query(tr[k].l);
if (q.top()<dr) query(tr[k].r);
}
else {
if (q.top()<dr) query(tr[k].r);
if (q.top()<dl) query(tr[k].l);
}
} int main() {
scanf("%d%d",&n,&K);
for (int i=1;i<=n;i++) {
scanf("%d%d",&tr[i].v[0],&tr[i].v[1]);
tr[i].mn[0]=tr[i].mx[0]=tr[i].v[0];
tr[i].mn[1]=tr[i].mx[1]=tr[i].v[1];
}
rt=build(1,n,0);
for (int i=1;i<=2*K;i++) q.push(0);
for (int i=1;i<=n;i++) S=tr[i],query(rt);
printf("%lld",q.top());
return 0;
}

  

【bzoj4520】 Cqoi2016—K远点对的更多相关文章

  1. [BZOJ4520][Cqoi2016]K远点对 kd-tree 优先队列

    4520: [Cqoi2016]K远点对 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 1285  Solved: 708[Submit][Statu ...

  2. [bzoj4520][Cqoi2016]K远点对_KD-Tree_堆

    K远点对 bzoj-4520 Cqoi-2016 题目大意:已知平面内 N 个点的坐标,求欧氏距离下的第 K 远点对. 注释:$1\le n\le 10^5$,$1\le k\le 100$,$k\l ...

  3. BZOJ4520 [Cqoi2016]K远点对

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...

  4. BZOJ4520:[CQOI2016]K远点对(K-D Tree)

    Description 已知平面内 N 个点的坐标,求欧氏距离下的第 K 远点对. Input 输入文件第一行为用空格隔开的两个整数 N, K.接下来 N 行,每行两个整数 X,Y,表示一个点 的坐标 ...

  5. 【BZOJ4520】[Cqoi2016]K远点对 kd-tree+堆

    [BZOJ4520][Cqoi2016]K远点对 Description 已知平面内 N 个点的坐标,求欧氏距离下的第 K 远点对. Input 输入文件第一行为用空格隔开的两个整数 N, K.接下来 ...

  6. 【BZOJ-4520】K远点对 KD-Tree + 堆

    4520: [Cqoi2016]K远点对 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 490  Solved: 237[Submit][Status ...

  7. BZOJ 4520: [Cqoi2016]K远点对

    4520: [Cqoi2016]K远点对 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 638  Solved: 340[Submit][Status ...

  8. 【BZOJ4520】K远点对(KD-Tree)

    [BZOJ4520]K远点对(KD-Tree) 题面 BZOJ 洛谷 题解 考虑暴力. 维护一个大小为\(K\)的小根堆,然后每次把两个点之间的距离插进去,然后弹出堆顶 这样子可以用\(KD-Tree ...

  9. [Cqoi2016]K远点对 K-Dtree

    4520: [Cqoi2016]K远点对 链接 bzoj 思路 用K-Dtree求点的最远距离. 求的时候顺便维护一个大小为2k的小根堆. 不知道为啥一定会对. 代码 #include <bit ...

随机推荐

  1. [转载]MySQL面试题

    1.MySQL的复制原理以及流程基本原理流程,3个线程以及之间的关联:(1)主:binlog线程——记录下所有改变了数据库数据的语句,放进master上的binlog中:(2)从:io线程——在使用s ...

  2. Netty源码分析第5章(ByteBuf)---->第9节: ByteBuf回收

    Netty源码分析第五章: ByteBuf 第九节: ByteBuf回收 之前的章节我们提到过, 堆外内存是不受jvm垃圾回收机制控制的, 所以我们分配一块堆外内存进行ByteBuf操作时, 使用完毕 ...

  3. java抽象类与接口区别

    java抽象类与接口区别: abstract class和interface是Java语言中对于抽象类定义进行支持的两种机制,正是由于这两种机制的存在,才赋予了Java强大的面向对象能力. abstr ...

  4. centos6.9 安装完xampp 7.2.0后,执行/opt/lampp/lampp报错

    # /opt/lampp/lampp egrep: error while loading shared libraries: libc.so.6: cannot open shared object ...

  5. LVS 负载均衡 keepalive

    为什么要学lvs 工作在网络模型的7层,可以针对http应用做一些分流的策略,比如针对域名.目录结构, Nginx单凭这点可利用的场合就远多于LVS了.最新版本的Nginx也支持4层TCP负载,曾经这 ...

  6. python之multiprocessing创建进程

    python的multiprocessing模块是用来创建多进程的,下面对multiprocessing总结一下使用记录. multiprocessing创建多进程在windows和linux系统下的 ...

  7. “Hello World!”团队第六周第六次会议

    “Hello World!”团队第六周第六次会议   博客内容: 一.会议时间 二.会议地点 三.会议成员 四.会议内容 五.todo list 六.会议照片 七.燃尽图 八.checkout& ...

  8. java.util.ConcurrentModificationException: null

    是因为在map.foreach中又put新的值了 在map.foreach中可能是不可以增删改

  9. 10.29 scrum meeting newbe软件团队工作分配

    这次会议,我们主要讨论了目前阶段的主要任务与任务分配问题. 首先,通读代码,理解程序的运行方式是必不可少的环节.所以我们要求团队的所有成员通读代码.并且对于开发人员和测试人员,要求写出我们分配的各自模 ...

  10. HDU 4568 Hunter 最短路+TSP

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4568 Hunter Time Limit: 2000/1000 MS (Java/Others)Me ...