学习了一下kd-tree的基本写法 http://blog.csdn.net/jiangshibiao/article/details/34144829 配合 http://www.bilibili.com/video/av7039143/ 食用

不过这个博客的里面那道2648的代码是错的 应该加上一句if(n)build 否则应该在插入第一个黑点的时候建树

kd-tree的写法还是很简单的 如果学习过线段树 应该很容易就学会了模板了

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<map>
#include<math.h>
#include<queue>
#include<string>
using namespace std;
#define L long long
const int INF = 999999999 ;
int n , m , root , cmp_d ;
int x, y ;
struct node{
int d[2] , Max[2] , Min[2] ;
int l, r ;
}tr[1000050];
bool cmp(node a , node b){
return a.d[cmp_d] < b.d[cmp_d] || a.d[cmp_d] == b.d[cmp_d] && a.d[cmp_d^1] < b.d[cmp_d^1];
}
void up(int p,int k){
if(tr[k].Max[0] > tr[p].Max[0]) tr[p].Max[0] = tr[k].Max[0] ;
if(tr[k].Max[1] > tr[p].Max[1]) tr[p].Max[1] = tr[k].Max[1] ;
if(tr[k].Min[0] < tr[p].Min[0]) tr[p].Min[0] = tr[k].Min[0] ;
if(tr[k].Min[1] < tr[p].Min[1]) tr[p].Min[1] = tr[k].Min[1] ;
}
int build(int l,int r, int D){
int mid = (l+r) >> 1;
cmp_d = D;
nth_element(tr+l+1,tr+mid+1,tr+r+1,cmp) ;
tr[mid].Max[0] = tr[mid].Min[0] = tr[mid].d[0];
tr[mid].Max[1] = tr[mid].Min[1] = tr[mid].d[1];
if(l!=mid)
tr[mid].l = build(l,mid-1,D^1) ;
else tr[mid].l = 0;
if(r!=mid)
tr[mid].r = build(mid+1,r,D^1);
else tr[mid].r = 0;
if(tr[mid].l)up(mid,tr[mid].l);
if(tr[mid].r)up(mid,tr[mid].r);
return mid ;
}
void inse(int k){
int p = root ;
int D = 0 ;
while(true){
up(p,k);
if(tr[k].d[D] <= tr[p].d[D]){
if(!tr[p].l){
tr[p].l = k ;
return;
}
p = tr[p].l ;
}
else {
if(!tr[p].r){
tr[p].r = k ;
return;
}
p = tr[p].r ;
}
D ^= 1;
}
}
int ans ;
int getdis(int p,int x,int y){
int res = 0;
if(x > tr[p].Max[0])res += x - tr[p].Max[0];
if(x < tr[p].Min[0])res += tr[p].Min[0] - x;
if(y > tr[p].Max[1])res += y - tr[p].Max[1];
if(y < tr[p].Min[1])res += tr[p].Min[1] - y;
return res ;
}
void ask(int p){
int d0 = abs(x - tr[p].d[0]) + abs(y - tr[p].d[1]) ;
if(d0<ans)ans = d0 ;
int dl , dr ;
if(tr[p].l)dl=getdis(tr[p].l,x,y) ;else dl = INF ;
if(tr[p].r)dr=getdis(tr[p].r,x,y) ;else dr = INF ;
if(dl < dr){
if(dl < ans)ask(tr[p].l) ;
if(dr < ans)ask(tr[p].r) ;
}
else {
if(dr < ans)ask(tr[p].r) ;
if(dl < ans)ask(tr[p].l) ;
}
} int main(){
scanf("%d%d",&n,&m);
for(int i = 1; i <= n ; i ++ ){
scanf("%d%d",&tr[i].d[0] , &tr[i].d[1]);
}
if(n)
root = build(1,n,0) ;
for(int i = 1; i <= m ; i ++ ){
int q;
scanf("%d%d%d",&q,&x,&y);
if(q == 1){
n ++ ;
tr[n].d[0]=tr[n].Max[0]=tr[n].Min[0]=x;
tr[n].d[1]=tr[n].Max[1]=tr[n].Min[1]=y;
if(n>1)
inse(n);
else {
root = build(1,n,0);
}
}
else {
ans = INF;
ask(root);
printf("%d\n",ans);
}
}
}

  

BZOJ 2648 kd-tree模板的更多相关文章

  1. k-d tree模板练习

    1. [BZOJ]1941: [Sdoi2010]Hide and Seek 题目大意:给出n个二维平面上的点,一个点的权值是它到其他点的最长距离减最短距离,距离为曼哈顿距离,求最小权值.(n< ...

  2. BZOJ 2648 / 2716 K-D Tree 模板题

    #include <cstdio> #include <cmath> #include <cstring> #include <algorithm> # ...

  3. BZOJ - 2648 KD树 最近点查询

    省赛后躺尸几天又回来更新了,内容是说好的KD树.. 具体操作从代码中感受一下 感觉已经把KD树尽量封装好了(虽然全局的D看着极不顺眼) 需要注意的是估值函数的判断条件 #include<bits ...

  4. 【BZOJ-2648&2716】SJY摆棋子&天使玩偶 KD Tree

    2648: SJY摆棋子 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 2459  Solved: 834[Submit][Status][Discu ...

  5. kd-tree注解 &amp; bzoj 2648 &amp; 2716 &amp; 3053 解决问题的方法

    [KD-TREE简介]于SYC1999大神"迷住"下一个.我开始接触这样的算法. 首先.这个概念大概能去百度百科.详细的实施.我在看RZZ的代码长大的. 我们能够想象在平面上有N个 ...

  6. BZOJ2648/2716:SJY摆棋子/[Violet]天使玩偶(K-D Tree)

    Description 这天,SJY显得无聊.在家自己玩.在一个棋盘上,有N个黑色棋子.他每次要么放到棋盘上一个黑色棋子,要么放上一个白色棋子,如果是白色棋子,他会找出距离这个白色棋子最近的黑色棋子. ...

  7. BZOJ 2648: SJY摆棋子(K-D Tree)

    Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 6051  Solved: 2113[Submit][Status][Discuss] Descript ...

  8. [模板] K-D Tree

    K-D Tree K-D Tree可以看作二叉搜索树的高维推广, 它的第 \(k\) 层以所有点的第 \(k\) 维作为关键字对点做出划分. 为了保证划分均匀, 可以以第 \(k\) 维排名在中间的节 ...

  9. BZOJ 3489: A simple rmq problem(K-D Tree)

    Time Limit: 40 Sec  Memory Limit: 512 MBSubmit: 2579  Solved: 888[Submit][Status][Discuss] Descripti ...

  10. BZOJ 3053: The Closest M Points(K-D Tree)

    Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1235  Solved: 418[Submit][Status][Discuss] Descripti ...

随机推荐

  1. 【Swift初见】SourceKitService Terminated

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/weasleyqi/article/details/36162085 心血来潮想试试最新的Xcode6 ...

  2. Android中 Application的使用

    Application全局唯一,如果需要放置全局的变量,需要用到Application,类似于OC中的单例类,获者OC中的AppDelegate 第一步:创建一个AppContext继承Applica ...

  3. 高性能mysql 4 ,5章

    第4章 1:查询优化,多表连接时只取需要的列,要对select * 保持怀疑. 2:如果发现访问的数据行数很大,而生成的结果中数据行很少,那么可以尝试更复杂的修改 a: 使用覆盖索引,b: 更改架构, ...

  4. Spark Streaming性能优化: 如何在生产环境下应对流数据峰值巨变

    1.为什么引入Backpressure 默认情况下,Spark Streaming通过Receiver以生产者生产数据的速率接收数据,计算过程中会出现batch processing time > ...

  5. MySQL IFNULL()函数用法MySQL

    用法说明:IFNULL(expr1,expr2) 如果 expr1 不是 NULL,IFNULL() 返回 expr1,否则它返回 expr2. IFNULL()返回一个数字或字符串值,取决于它被使用 ...

  6. Andrew Ng-ML习题答案1

    1.Linear Regression with Multiple Variables 转自:https://blog.csdn.net/mupengfei6688/article/details/5 ...

  7. Locust性能测试1-环境准备与基本使用

    前言 提到性能测试,大部分小伙伴想到的就是LR和jmeter这种工具,小编一直不太喜欢写这种工具类的东西,我的原则是能用代码解决的问题,尽量不去用工具. python里面也有一个性能测试框架Locus ...

  8. django学习网站

    http://www.ziqiangxuetang.com/django/django-qrcode.html

  9. 20154312 曾林 Exp5_MSF基础应用

    --目录-- MSF渗透测试-CVE-2017-11882 1.基础内容回答 2.实践过程记录 2.1.主动攻击实践-ms08_067 2.2.针对浏览器的攻击-ms10_046 2.3.针对客户端的 ...

  10. sql性能优化(摘自网络)

    索引,索引!!!为经常查询的字段建索引!! 但也不能过多地建索引.insert和delete等改变表记录的操作会导致索引重排,增加数据库负担. 优化目标 1.减少 IO 次数 IO永远是数据库最容易瓶 ...