K-D树:bzoj 1941: [Sdoi2010]Hide and Seek (板子)

  1 #include<cstdio>
  2 #include<cstring>
  3 #include<iostream>
  4 #include<algorithm>
  5 #define ls(x) a[x].l
  6 #define rs(x) a[x].r
  7 using namespace std;
  8 const int N=500066;
  9 int abss(int x){return x<0?-x:x;}
 10 int maxn(int a,int b){return a>b?a:b;}
 11 int minn(int a,int b){return a<b?a:b;}
 12 void swap(int &x,int &y){x^=y;y^=x;x^=y;}
 13
 14 int cmpid,n,ans;
 15 struct son
 16 {
 17     int x[2];
 18     friend bool operator < (son a,son b)
 19     {
 20         return a.x[cmpid]>b.x[cmpid];
 21     }
 22 }p[N];
 23
 24 struct tree
 25 {
 26     son p;
 27     int mx[2],mn[2],l,r;
 28 }a[N];
 29 int dis(son a,son b){return abss(a.x[0]-b.x[0])+abss(a.x[1]-b.x[1]);}
 30 int maxdis(tree t,son c)
 31 {
 32     int temp1=maxn( abss(c.x[0]-t.mn[0]),abss(c.x[0]-t.mx[0]) );
 33     int temp2=maxn( abss(c.x[1]-t.mn[1]),abss(c.x[1]-t.mx[1]) );
 34     return temp1+temp2;
 35 }
 36 int mindis(tree t,son c)
 37 {
 38     int temp1=maxn(t.mn[0]-c.x[0],0)+maxn(c.x[0]-t.mx[0],0);
 39     int temp2=maxn(t.mn[1]-c.x[1],0)+maxn(c.x[1]-t.mx[1],0);
 40     return temp1+temp2;
 41 }
 42
 43 struct KDtree
 44 {
 45     int ans,root,tot,temp;
 46     void qqmax(son q,int x,int k)
 47     {
 48         if(!x)return ;
 49         temp=dis(a[x].p,q);
 50         if(temp>ans)ans=temp;
 51         int l=ls(x),r=rs(x);
 52         if(q.x[k]<a[x].p.x[k])swap(l,r);//右边更有可能
 53         if(ans<maxdis(a[l],q))qqmax(q,l,k^1);
 54         if(ans<maxdis(a[r],q))qqmax(q,r,k^1);
 55     }
 56     int qqmax(son q)
 57     {
 58         ans=-0x7fffffff;
 59         qqmax(q,root,0);
 60         return ans;
 61     }
 62     void qqmin(son q,int x,int k)
 63     {
 64         if(!x)return ;
 65         temp=dis(a[x].p,q);
 66         if(temp<ans&&temp)ans=temp;
 67         int l=ls(x),r=rs(x);
 68         if(q.x[k]>a[x].p.x[k])swap(l,r);//也是右边更有可能
 69         if(mindis(a[l],q)<ans)qqmin(q,l,k^1);
 70         if(mindis(a[r],q)<ans)qqmin(q,r,k^1);
 71     }
 72     int qqmin(son q)
 73     {
 74         ans=0x7fffffff;
 75         qqmin(q,root,0);
 76         return ans;
 77     }
 78     void pushup(int x)
 79     {
 80         if(!x)return ;
 81         if(ls(x))
 82           for(int i=0;i<2;++i)
 83             {
 84                 a[x].mn[i]=minn(a[x].mn[i],a[ls(x)].mn[i]);
 85                 a[x].mx[i]=maxn(a[x].mx[i],a[ls(x)].mx[i]);
 86             }
 87         if(rs(x))
 88           for(int i=0;i<2;++i)
 89           {
 90                 a[x].mn[i]=minn(a[x].mn[i],a[rs(x)].mn[i]);
 91                 a[x].mx[i]=maxn(a[x].mx[i],a[rs(x)].mx[i]);
 92             }
 93     }
 94     void build(int l,int r,int &x,int k)
 95     {
 96         if(l>r)return ;
 97         x=++tot;
 98         int mid=(l+r)>>1;
 99         cmpid=k;
100         nth_element(p+l,p+mid,p+r+1);
101         a[x].p=p[mid];
102         for(int i=0;i<2;++i)
103           a[x].mn[i]=a[x].mx[i]=a[x].p.x[i];
104         build(l,mid-1,ls(x),k^1);
105         build(mid+1,r,rs(x),k^1);
106         pushup(x);
107     }
108     void build()
109     {
110         tot=0;
111         build(1,n,root,0);
112     }
113 }T;
114 int main(){
115
116     scanf("%d",&n);
117     for(int i=1;i<=n;++i)
118       scanf("%d%d",&p[i].x[0],&p[i].x[1]);
119
120     T.build();
121
122     ans=0x7fffffff;
123
124     for(int i=1;i<=n;++i)
125       ans=minn(ans,T.qqmax(p[i])-T.qqmin(p[i]));
126
127     cout<<ans;
128     //while(1);
129     return 0;
130 }

code

时间: 2024-10-13 11:16:20

K-D树:bzoj 1941: [Sdoi2010]Hide and Seek (板子)的相关文章

bzoj:1941: [Sdoi2010]Hide and Seek

1941: [Sdoi2010]Hide and Seek Time Limit: 16 Sec  Memory Limit: 162 MBSubmit: 531  Solved: 295[Submit][Status][Discuss] Description 小猪iPig在PKU刚上完了无聊的猪性代数课,天资聪慧的iPig被这门对他来说无比简单的课弄得非常寂寞,为了消除寂寞感,他决定和他的好朋友giPi(鸡皮)玩一个更加寂寞的游戏---捉迷藏. 但是,他们觉得,玩普通的捉迷藏没什么意思,还是

BZOJ 1941: [Sdoi2010]Hide and Seek(k-d Tree)

Time Limit: 16 Sec  Memory Limit: 162 MBSubmit: 1712  Solved: 932[Submit][Status][Discuss] Description 小猪iPig在PKU刚上完了无聊的猪性代数课,天资聪慧的iPig被这门对他来说无比简单的课弄得非常寂寞,为了消除寂寞感,他决定和他的好朋友giPi(鸡皮)玩一个更加寂寞的游戏---捉迷藏. 但是,他们觉得,玩普通的捉迷藏没什么意思,还是不够寂寞,于是,他们决定玩寂寞无比的螃蟹版捉迷藏,顾名思义

BZOJ 1941 Sdoi2010 Hide and Seek K-Dimensional-Tree

题目大意:给定平面上的n个点,定义距离为曼哈顿距离,求一个点到其他所有点的最大距离与最小距离之差最小 KDTree--这东西好神啊 注意计算最小距离的时候不能把自己也算进去= = #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define M 500500 #define INF 0x3f3f3f3f using namespace std; st

bzoj1941 [Sdoi2010]Hide and Seek

Description 小猪iPig在PKU刚上完了无聊的猪性代数课,天资聪慧的iPig被这门对他来说无比简单的课弄得非常寂寞,为了消除寂寞感,他决定和他的好朋友giPi(鸡皮)玩一个更加寂寞的游戏---捉迷藏. 但是,他们觉得,玩普通的捉迷藏没什么意思,还是不够寂寞,于是,他们决定玩寂寞无比的螃蟹版捉迷藏,顾名思义,就是说他们在玩游戏的时候只能沿水平或垂直方向走.一番寂寞的剪刀石头布后,他们决定iPig去捉giPi.由于他们都很熟悉PKU的地形了,所以giPi只会躲在PKU内n个隐秘地点,显然

【bzoj1941】 Sdoi2010—Hide and Seek

http://www.lydsy.com/JudgeOnline/problem.php?id=1941 (题目链接) 题意 给出n个二维平面上的点,求一点使到最远点的距离-最近点的距离最小. Solution KDtree板子,早就听jump说KDtree都是板子题→_→ 枚举点,求其最远点距离和最近点距离,更新答案.最远邻近域搜索跟最近差不多,就是把估价函数改一下. 细节 码农题注意细节 代码 // bzoj1941 #include<algorithm> #include<iost

【bzoj1941】[Sdoi2010]Hide and Seek KD-tree

题目描述 小猪iPig在PKU刚上完了无聊的猪性代数课,天资聪慧的iPig被这门对他来说无比简单的课弄得非常寂寞,为了消除寂寞感,他决定和他的好朋友giPi(鸡皮)玩一个更加寂寞的游戏---捉迷藏. 但是,他们觉得,玩普通的捉迷藏没什么意思,还是不够寂寞,于是,他们决定玩寂寞无比的螃蟹版捉迷藏,顾名思义,就是说他们在玩游戏的时候只能沿水平或垂直方向走.一番寂寞的剪刀石头布后,他们决定iPig去捉giPi.由于他们都很熟悉PKU的地形了,所以giPi只会躲在PKU内n个隐秘地点,显然iPig也只会

【kd-tree】bzoj1941 [Sdoi2010]Hide and Seek

枚举每个点,计算离他最近的和最远的点. #include<cstdio> #include<cmath> #include<algorithm> using namespace std; #define N 500001 #define INF 2147483647 #define KD 2//ά¶ÈÊý int qp[KD],disn,disx; int n,root; bool dn; struct Node { int minn[KD],maxx[KD],p[K

【BZOJ】【1941】【SDOI2010】Hide and Seek

KD-Tree 一开始看错题了 其实是:给定n个点,从中找一个点,使得其他所有点到它距离的最大值与最小值之差最小. 利用KD-Tree暴力求出每个点的答案(找离它最近的点以及最远的点(当然只关心距离)) 然后……两个过程分开写…… 注意一下最近的点的距离不能是0(然而我一开始用 if (o==tmp) return INF; 就WA了……)(这里o是当前搜索到的点,tmp是枚举的起始点) 1 /***************************************************

【BZOJ-1941】Hide and Seek KD-Tree

1941: [Sdoi2010]Hide and Seek Time Limit: 16 Sec  Memory Limit: 162 MBSubmit: 830  Solved: 455[Submit][Status][Discuss] Description 小猪iPig在PKU刚上完了无聊的猪性代数课,天资聪慧的iPig被这门对他来说无比简单的课弄得非常寂寞,为了消除寂寞感,他决定和他的好朋友giPi(鸡皮)玩一个更加寂寞的游戏---捉迷藏. 但是,他们觉得,玩普通的捉迷藏没什么意思,还是