【bzoj4520】 Cqoi2016—K远点对
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远点对的更多相关文章
- [BZOJ4520][Cqoi2016]K远点对 kd-tree 优先队列
4520: [Cqoi2016]K远点对 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 1285 Solved: 708[Submit][Statu ...
- [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 ...
- BZOJ4520 [Cqoi2016]K远点对
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- BZOJ4520:[CQOI2016]K远点对(K-D Tree)
Description 已知平面内 N 个点的坐标,求欧氏距离下的第 K 远点对. Input 输入文件第一行为用空格隔开的两个整数 N, K.接下来 N 行,每行两个整数 X,Y,表示一个点 的坐标 ...
- 【BZOJ4520】[Cqoi2016]K远点对 kd-tree+堆
[BZOJ4520][Cqoi2016]K远点对 Description 已知平面内 N 个点的坐标,求欧氏距离下的第 K 远点对. Input 输入文件第一行为用空格隔开的两个整数 N, K.接下来 ...
- 【BZOJ-4520】K远点对 KD-Tree + 堆
4520: [Cqoi2016]K远点对 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 490 Solved: 237[Submit][Status ...
- BZOJ 4520: [Cqoi2016]K远点对
4520: [Cqoi2016]K远点对 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 638 Solved: 340[Submit][Status ...
- 【BZOJ4520】K远点对(KD-Tree)
[BZOJ4520]K远点对(KD-Tree) 题面 BZOJ 洛谷 题解 考虑暴力. 维护一个大小为\(K\)的小根堆,然后每次把两个点之间的距离插进去,然后弹出堆顶 这样子可以用\(KD-Tree ...
- [Cqoi2016]K远点对 K-Dtree
4520: [Cqoi2016]K远点对 链接 bzoj 思路 用K-Dtree求点的最远距离. 求的时候顺便维护一个大小为2k的小根堆. 不知道为啥一定会对. 代码 #include <bit ...
随机推荐
- sqli-labs学习笔记 DAY4
DAY 4 sqli-labs lesson 23 与lesson 1一样,只不过屏蔽了#和–注释符. 报错型注入: 爆库:id=99' UNION SELECT 1,extractvalue(1,c ...
- 配置Ubuntu16.04虚拟机 (用途:CTF_pwn)
因为学习需要16.xx的虚拟机,所以把之前18.04的Ubuntu卸掉重装了一遍Ubuntu16.04, 考虑到我有备份和重装系统的爱好,故记之,以备后用. 目录: //最后更新时间:190122·1 ...
- LEETCODE —— Unique Paths II [Dynamic Programming]
唯一路径问题II Unique Paths II Follow up for "Unique Paths": Now consider if some obstacles are ...
- iOS 模块化、组件化方案探索(利用cocoapods 、git 创建私有仓库)
来自bang's blog http://blog.cnbang.net/tech/3080/ 模块化 简单来说,模块化就是将一个程序按照其功能做拆分,分成相互独立的模块,以便于每个模块只包含与其功能 ...
- hexo主题中添加相册功能
博客已迁移至http://lwzhang.github.io. 基本上所有的hexo主题默认都没有实现相册功能,一方面相册功能的需求较少,毕竟hexo主要是写博客用的:另一方面实现相册功能比较麻烦,比 ...
- webpack入门指南-step02
webpack 安装 1)安装前的准备:webpack是基于node环境的项目,所以使用前必须先安装node和npm. 在安装 Webpack 前,你本地环境需要支持 node.js.如果电脑没有装过 ...
- MathExam6378
我的第一个程序 一.预估与实际 PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟) Planning 计划 15 10 • Estima ...
- Linux手动添加系统环境共享库路径
1.在以下目录 #/etc/ld.so.conf.d 添加相应的xxx.conf 2.写入所要共享库的路径 如:/usr/lib/ 3.导入共享库配置 $ldconfig
- bata6
目录 组员情况 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:恺琳 组员6:翟丹丹 组员7:何家伟 组员8:政演 组员9:黄鸿杰 组员10:刘一好 组员11:何宇恒 展示组内最新成果 团队签入记 ...
- 注册表:DWORD
百度百科 DWORD全称Double Word,是指注册表的键值,每个word为2个字节的长度,DWORD 双字即为4个字节,每个字节是8位,共32位. 在键值项窗口空白处单击右键,选择“新建”菜单项 ...