应用于K维数据的快速查找,比如横坐标,纵坐标,价格……,本模板以16青岛区域赛K题为例 —— 三维K - D Tree 模板
我们应该都见过平衡树吧,那就是1-D树,变成k维之后,我们连续分割1 - k维,然后继续分割,实现快速查找,画图的时候就能够理解这个数据结构了
n个旅馆 x,y,csot
m个用户 x,y,limitcost
问你每个用户在可以接受的价格内距离最近的旅馆是哪个 #define deep 3 // K-D树的维度
#define inf (1e18) //用ll防止开根号,造成浮点误差
using namespace std;
typedef long long ll;
const int maxn = 2e5+2e3;
int retid;//最优的旅馆选择编号
ll ans;//判断距离最小值
int loc;//当前进行的维度
int n,m;//n个旅馆,m个顾客
struct node{
int id;
int data[deep];
//对各个维度都从小到大排序
bool operator < (const node &b) const{
if(data[loc] < b.data[loc])
return 1;
return 0;
}
}P[maxn],tmp[maxn],Now,Aim;//P数组排序,tmp数组副本作为输出
void creat_KDtree(int l,int r,int flor){
if(l >= r){
return;
}
int mid = (l + r) >> 1;
loc = flor % deep;
nth_element(P+l,P+mid,P+r+1);
/*把p+mid元素放在中间位置,使其左边元素比它小,右边比它大
nth_element(first,nth,last)
first,last 第一个和最后一个迭代器,也可以直接用数组的位置。
nth,要定位的第n个元素,能对它进行随机访问.
将第n_th元素放到它该放的位置上,左边元素都小于它,右边元素都大于它.*/
creat_KDtree(l,mid-1,flor+1);
creat_KDtree(mid+1,r,flor+1);
}
void judge(int x)//根据题意的判断函数{
Now = P[x];
if(Now.data[2] > Aim.data[2])
return;
ll dis = (Now.data[0] - Aim.data[0]) * (Now.data[0] - Aim.data[0]) + (Now.data[1] - Aim.data[1]) * (Now.data[1] - Aim.data[1]);
if(dis < ans || dis == ans && Now.id < retid){
ans = dis;
retid = Now.id;
}
}
void Find(int l,int r,int flor)//也是根据题意来写{
loc = flor % deep;
if(l >= r){
if(l == r)
judge(l);
return;
}
int mid = (l + r) >> 1;
judge(mid);
Now = P[mid];
if(loc == 2){
if(Now.data[loc] >= Aim.data[loc])
Find(l,mid-1,flor+1);
else{
Find(l,mid-1,flor+1);
Find(mid+1,r,flor+1);
}
}
else{
int len = Now.data[loc] - Aim.data[loc];
if(len >= 0){
Find(l,mid-1,flor+1);
if(((ll)len * len) < ans){
Find(mid+1,r,flor+1);
}
}
else{
Find(mid+1,r,flor+1);
if(((ll)len * len) < ans){
Find(l,mid-1,flor+1);
}
}
}
}

K-DTree学习的更多相关文章

  1. 编程语言教程书该怎么写: 向K&R学习!

    原文地址:Lax Language TutorialsAndrew Binstock 每年在评审Jolt Awards图书的时候,我都会被一些语言教程类图书弄得心力交瘁.从这些年的评审经验来看,这些语 ...

  2. 2. K线学习知识二

    1. K线 - 阳线 定义:阳线是证券市场上指收盘价高于开盘价的K线,K线图中用红线标注表示涨势. A:小阳星 全日中股价波动很小,开盘价与收盘价极其接近,收盘价略高于开盘价. 小阳星的出现,表明行情 ...

  3. A* k短路 学习笔记

    题目大意 n个点,m条边有向图,给定S,T,求不严格k短路 n<=1000 m<=100000 k<=1000 不用LL 分析 A*算法 f(i)表示从S出发经过i到T的估价函数 \ ...

  4. K短路 学习笔记

    K短路,顾名思义,是让你求从$s$到$t$的第$k$短的路. 暴力当然不可取,那么我们有什么算法可以解决这个问题? -------------------------- 首先,我们要维护一个堆. st ...

  5. 初涉深度优先搜索--Java学习笔记(二)

    版权声明: 本文由Faye_Zuo发布于http://www.cnblogs.com/zuofeiyi/, 本文可以被全部的转载或者部分使用,但请注明出处. 上周学习了数组和链表,有点基础了解以后,这 ...

  6. BZOJ3442: 学习小组

    Description [背景] 坑校准备鼓励学生参加学习小组. [描述]     共有n个学生,m个学习小组,每个学生有一定的喜好,只愿意参加其中的一些学习小组,但是校领导为学生考虑,规定一个学生最 ...

  7. 【BZOJ】【3442】学习小组

    网络流/费用流 orz zyf 裸的费用流,根据题目描述即可建出如下的图: S->i 费用表示每有一个加入第 i 个小组的学生,需要花的钱,由于是跟流量(人数)的二次方相关,所以要拆边……然后每 ...

  8. 20165308 预备作业3 Linux安装及学习

    Linux安装及学习 Linux的安装 因为做的比较晚, 安装过程按照老师给出的步骤和同学指导并未出现很多问题,只是安装VirtualBox虚拟机增强功能时,代码没输正确,结果一直无法正确安装,后来也 ...

  9. 深度学习在CTR预估中的应用

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由鹅厂优文发表于云+社区专栏 一.前言 二.深度学习模型 1. Factorization-machine(FM) FM = LR+ e ...

  10. 【刷题】洛谷 P4209 学习小组

    题目描述 共有n个学生,m个学习小组,每个学生只愿意参加其中的一些学习小组,且一个学生最多参加k个学习小组.每个学生参加学习小组财务处都收一定的手续费,不同的学习小组有不同的手续费.若有a个学生参加第 ...

随机推荐

  1. hibernate NUMBER 精度

    通过Hibernate映射实体时会根据数据库中NUMBER类型的精度,生成相应的POJO类中相对应的主键类型.经过亲测结果如下: NUMBER(1) POJO类中生成的是Boolean publicc ...

  2. JUnit源码分析 - 扩展 - 自定义Rule

    JUnit Rule简述 Rule是JUnit 4.7之后新加入的特性,有点类似于拦截器,可以在测试类或测试方法执行前后添加额外的处理,本质上是对@BeforeClass, @AfterClass, ...

  3. SpringCloud Hystrix熔断之线程池

    服务熔断 雪崩效应:是一种因服务提供者的不可用导致服务调用者的不可用,并导致服务雪崩的过程. 服务熔断:当服务提供者无法调用时,会通过断路器向调用方直接返回一个错误响应,而不是长时间的等待,避免服务雪 ...

  4. Tomcat start.bat闪退:JRE_HOME环境变量配置不对

    最近在配置Tomcat上遇到startup.bat启动闪退,在网上找了很多方法,都没解决.后来在网上找到两种问题,更改了两次,解决了.现将我遇到的问题分享,希望对遇到同样问题有帮助. 1.很多初学者对 ...

  5. SpringBoot集成RabbitMQ 从零到一,学会MQ异步和解耦--

    RabbitMQ 概念 RabbitMQ 即一个消息队列,_主要是用来实现应用程序的异步和解耦,同时也能起到消息缓冲,消息分发的作用._RabbitMQ使用的是AMQP协议,它是一种二进制协议.默认启 ...

  6. 查看 设置mysql时区

    # 查看时区 show variables like '%time_zone%'; system_time_zone CST time_zone SYSTEM # 设置全局 set global ti ...

  7. golang项目:goa和micro

    https://github.com/goadesign/goa http://www.cnblogs.com/zhangqingping/p/5531171.html https://github. ...

  8. github分支规范

    转自:https://www.cnblogs.com/xuld 一.目的 我们制定分支规范,意在实现以下目标: 减少沟通成本:开发者可以很清晰地知道需要修改的代码位于哪个分支. 减少 bug 隐患:避 ...

  9. 关于Https

    http://blog.csdn.net/wfdtxz/article/details/8678982 https://www.tuicool.com/articles/feYfE3I https:/ ...

  10. Oracle启动和停止

    概述 只有具备sysdba和sysoper系统特权的用户才能启动和关闭数据库. 在启动数据库之前应该启动监听程序,否则就不能利用命令方式来管理数据库,包括启动和关闭数据库. 虽然数据库正常运行,但如果 ...