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

题意

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

Solution

  左转题解:jump

细节

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

  距离什么的开LL

代码

  1. // bzoj4520
  2. #include<algorithm>
  3. #include<iostream>
  4. #include<cstdlib>
  5. #include<cstring>
  6. #include<cstdio>
  7. #include<vector>
  8. #include<cmath>
  9. #include<queue>
  10. #define LL long long
  11. #define inf 1<<30
  12. #define Pi acos(-1.0)
  13. #define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
  14. using namespace std;
  15.  
  16. const int maxn=100010;
  17. int n,m,D,K,rt;
  18. priority_queue<LL,vector<LL>,greater<LL> > q;
  19.  
  20. struct KDtree {
  21. int l,r,v[2],mn[2],mx[2];
  22. friend bool operator < (const KDtree a,const KDtree b) {
  23. return a.v[D]<b.v[D];
  24. }
  25. }tr[maxn],S;
  26.  
  27. void update(int k) {
  28. for (int i=0;i<=1;i++) {
  29. if (tr[k].l) {
  30. tr[k].mn[i]=min(tr[k].mn[i],tr[tr[k].l].mn[i]);
  31. tr[k].mx[i]=max(tr[k].mx[i],tr[tr[k].l].mx[i]);
  32. }
  33. if (tr[k].r) {
  34. tr[k].mn[i]=min(tr[k].mn[i],tr[tr[k].r].mn[i]);
  35. tr[k].mx[i]=max(tr[k].mx[i],tr[tr[k].r].mx[i]);
  36. }
  37. }
  38. }
  39. int build(int l,int r,int p) {
  40. D=p;
  41. int mid=(l+r)>>1;
  42. nth_element(tr+l,tr+mid,tr+r+1);
  43. if (l<mid) tr[mid].l=build(l,mid-1,p^1);
  44. if (r>mid) tr[mid].r=build(mid+1,r,p^1);
  45. update(mid);
  46. return mid;
  47. }
  48. LL dis(LL x1,LL y1,LL x2,LL y2) {
  49. return (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
  50. }
  51. LL eva(int k) {
  52. LL lu=dis(S.v[0],S.v[1],tr[k].mn[0],tr[k].mn[1]);
  53. LL ru=dis(S.v[0],S.v[1],tr[k].mx[0],tr[k].mn[1]);
  54. LL ld=dis(S.v[0],S.v[1],tr[k].mn[0],tr[k].mx[1]);
  55. LL rd=dis(S.v[0],S.v[1],tr[k].mx[0],tr[k].mx[1]);
  56. return max(max(lu,ru),max(ld,rd));
  57. }
  58. void query(int k) {
  59. if (!k) return;
  60. LL d=dis(S.v[0],S.v[1],tr[k].v[0],tr[k].v[1]);
  61. if (q.top()<d) q.pop(),q.push(d);
  62. LL dl=eva(tr[k].l),dr=eva(tr[k].r);
  63. if (dl>dr) {
  64. if (q.top()<dl) query(tr[k].l);
  65. if (q.top()<dr) query(tr[k].r);
  66. }
  67. else {
  68. if (q.top()<dr) query(tr[k].r);
  69. if (q.top()<dl) query(tr[k].l);
  70. }
  71. }
  72.  
  73. int main() {
  74. scanf("%d%d",&n,&K);
  75. for (int i=1;i<=n;i++) {
  76. scanf("%d%d",&tr[i].v[0],&tr[i].v[1]);
  77. tr[i].mn[0]=tr[i].mx[0]=tr[i].v[0];
  78. tr[i].mn[1]=tr[i].mx[1]=tr[i].v[1];
  79. }
  80. rt=build(1,n,0);
  81. for (int i=1;i<=2*K;i++) q.push(0);
  82. for (int i=1;i<=n;i++) S=tr[i],query(rt);
  83. printf("%lld",q.top());
  84. return 0;
  85. }

  

【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. shell编程基础(转载)

    Shell编程基础 原作者 Leal:请参阅页面底部的编者列表. 授权许可: 创作共享署名协议 GNU 自由文档许可证 注意:本文仍然在持续的修订之中,且错漏之处可能较多.如果能够阅读英语的话,可以考 ...

  2. 金融科技行业 SDL(转载)

     都是一些检查项,值得借鉴,关键在于要能够落地 作者 沈发挺@美的金融科技下载打印版

  3. [shell] bash数组(for时排序)

    for处理时会自动把顺序按A-Z排序了 [root@XM-v106 ~]# bash b.sh A -> B -> C -> D -> E -> [root@XM-v10 ...

  4. FFmpeg简单转码程序--视频剪辑

    学习了雷神的文章,慕斯人分享精神,感其英年而逝,不胜唏嘘.他有分享一个转码程序<最简单的基于FFMPEG的转码程序>其中使用了filter(参考了ffmpeg.c中的流程),他曾说想再编写 ...

  5. Django_信号

    目录 Django信号介绍 Django内置信号 信号种类 信号注册 自定义信号 实测 内置信号 自定义信号 Django信号介绍 Django中提供了“信号调度”,用于在框架执行操作时解耦.通俗来讲 ...

  6. Scrum Meeting 10.30

    成员 今日任务 明日计划 用时 徐越 配置servlet环境,设计开发文档 设计开发文档,配置服务器,使得本地可以访问服务器 5h 武鑫 软件界面设计:学习使用Activity和Fragment 设计 ...

  7. 关于如何使用Microsoft Word发博客

    关于如何使用Microsoft Word发博客   PS:以Microsoft Word 2010为例作具体操作,实际上Microsoft Word 2007也可以完成该功能,略有差异,但是只能是20 ...

  8. 奔跑吧DKY——团队Scrum冲刺阶段-Day 5

    今日完成任务 谭鑫:继续解决背景音乐的问题,修改游戏中的bug. 黄宇塘:背景图片需重做,开始制作人物图片和背景图. 赵晓海:制作人物图及背景图. 方艺雯:制作人物图,编写博客. 王禹涵:继续解决背景 ...

  9. YQCB冲刺周第五天

    站立会议: 任务看板: 今天的任务为依旧为将用户记录的数据添加到数据库中,以及金额球的设置. 遇到的问题为金额球在jsp页面的显示.

  10. CentOS中Intel i350T4驱动安装

    2015.3.31 在linux*中直接按解决方法中安装i350驱动即可 *************************************************************** ...