hdu4347The Closest M Points kdtree

时间:2022-06-28 21:06:58

kdtree讲解:

https://blog.csdn.net/qing101hua/article/details/53228668

https://blog.csdn.net/acdreamers/article/details/44664645

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4347

给你一堆点,每次查询给一个点求和这个点最近的m个点是什么(距离是欧氏距离)

裸的kdtree

//#pragma comment(linker, "/stack:200000000")
//#pragma GCC optimize("Ofast,no-stack-protector")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
//#pragma GCC optimize("unroll-loops")
#include<bits/stdc++.h>
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define pi acos(-1.0)
#define ll long long
#define vi vector<int>
#define mod 1000000007
#define C 0.5772156649
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#define pil pair<int,ll>
#define pli pair<ll,int>
#define pii pair<int,int>
#define cd complex<double>
#define ull unsigned long long
#define base 1000000000000000000
#define fio ios::sync_with_stdio(false);cin.tie(0) using namespace std; const double g=10.0,eps=1e-;
const int N=+,maxn=+,inf=0x3f3f3f3f,INF=0x3f3f3f3f3f3f3f3f; int n,k,idx;
struct node{
int f[];
bool operator <(const node&rhs)const{
return f[idx]<rhs.f[idx];
}
}a[N];
priority_queue<pair<double,node> >q;
struct kdtree{
bool vis[N<<];
node date[N<<];
void build(int l,int r,int rt,int dep)
{
if(l>r)return ;
vis[rt]=;
vis[rt<<]=vis[rt<<|]=;
idx=dep%k;
int m=(l+r)>>;
nth_element(a+l,a+m,a+r+);
date[rt]=a[m];
build(l,m-,rt<<,dep+);
build(m+,r,rt<<|,dep+);
}
void query(node p,int m,int rt,int dep)
{
if(!vis[rt])return ;
printf("%d \n",rt);
pair<double,node>cur(,date[rt]);
for(int i=;i<k;i++)
cur.fi+=(cur.se.f[i]-p.f[i])*(cur.se.f[i]-p.f[i]);
int dim=dep%k;
bool fg=;
int x=rt<<,y=rt<<|;
if(p.f[dim]>=date[rt].f[dim])swap(x,y);
if(vis[x])query(p,m,x,dep+);
if(q.size()<m)q.push(cur),fg=;
else
{
if(cur.fi<q.top().fi)
{
q.pop();q.push(cur);
}
if((p.f[dim]-date[rt].f[dim])*(p.f[dim]-date[rt].f[dim])<q.top().fi)fg=;
}
if(vis[y]&&fg)query(p,m,y,dep+);
}
}kd;
int main()
{
while(scanf("%d%d",&n,&k)!=EOF)
{
for(int i=;i<n;i++)
for(int j=;j<k;j++)
scanf("%d",&a[i].f[j]);
kd.build(,n-,,);
int t;scanf("%d",&t);
while(t--)
{
node p;
for(int i=;i<k;i++)scanf("%d",&p.f[i]);
int m;scanf("%d",&m);
while(!q.empty())q.pop();
// printf("%d\n",idx);
kd.query(p,m,,);
printf("the closest %d points are:\n",m);
node ans[];
for(int i=;!q.empty();i++)ans[i]=q.top().se,q.pop();
for(int i=m-;i>=;i--)
for(int j=;j<k;j++)
printf("%d%c",ans[i].f[j],j==k-?'\n':' ');
}
}
return ;
}
/*********************** ***********************/

hdu4347The Closest M Points kdtree的更多相关文章

  1. HDU 4347 - The Closest M Points - &lbrack;KDTree模板题&rsqb;

    本文参考: https://www.cnblogs.com/GerynOhenz/p/8727415.html kuangbin的ACM模板(新) 题目链接:http://acm.hdu.edu.cn ...

  2. hud 4347 The Closest M Points&lpar;KD-Tree&rpar;

    传送门 解题思路 \(KD-Tree\)模板题,\(KD-Tree\)解决的是多维问题,它是一个可以储存\(K\)维数据的二叉树,每一层都被一维所分割.它的插入删除复杂度为\(log^2 n\),它查 ...

  3. 【BZOJ】3053&colon; The Closest M Points(kdtree)

    http://www.lydsy.com/JudgeOnline/problem.php?id=3053 本来是1a的QAQ.... 没看到有多组数据啊.....斯巴达!!!!!!!!!!!!!!!! ...

  4. &lbrack;hdu4347&rsqb;The Closest M Points&lpar;线段树形式kd-tree&rpar;

    解题关键:kdtree模板题,距离某点最近的m个点. #include<cstdio> #include<cstring> #include<algorithm> ...

  5. HDU 4347 &Tab;The Closest M Points (kdTree)

    赤果果的kdTree. 学习传送门:http://www.cnblogs.com/v-July-v/archive/2012/11/20/3125419.html 其实就是二叉树的变形 #includ ...

  6. bzoj 3053&colon; The Closest M Points【KD-tree】

    多维KDtree板子 左右儿子的估价用mn~mx当区间,假设区间里的数都存在:k维轮着做割点 #include<iostream> #include<cstdio> #incl ...

  7. 【kd-tree】bzoj3053 The Closest M Points

    同p2626.由于K比较小,所以不必用堆. #include<cstdio> #include<cstring> #include<cmath> #include& ...

  8. &lbrack;hdu4347&rsqb;The Closest M Points&lpar;平衡树式kdtree&rpar;

    解题关键:模板题(结合起来了) #include<iostream> #include<cstdio> #include<cstring> #include< ...

  9. 【BZOJ 3053】The Closest M Points

    KDTree模板,在m维空间中找最近的k个点,用的是欧几里德距离. 理解了好久,昨晚始终不明白那些“估价函数”,后来才知道分情况讨论,≤k还是=k,在当前这一维度距离过线还是不过线,过线则要继续搜索另 ...

随机推荐

  1. Xstream学习资料

    java中有关xml操作的,我们项目中首推Xstream.至于原因不说了.跟着大众的脚步走应该没错的.有关Xstream的文档如下. 官方文档 XStream完美转换XML.JSON XStream实 ...

  2. Gvim插件管理Vundle

    之前关于gvim的博客中提到的很多插件安装比较繁琐,这一篇来介绍一下gvim管理插件的插件--vundle的安装以及使用,让givm的插件安装更加的简单 首先给出vundle的git地址 https: ...

  3. 第 26 章 CSS3 动画效果

    学习要点: 1.动画简介 2.属性详解 3.简写和版本 主讲教师:李炎恢 本章主要探讨 HTML5 中 CSS3 的动画效果,可以通过类似 Flash 那样的关键帧模式控制运行. 一.动画简介 CSS ...

  4. hdu 4712 Hamming Distance &lpar; 随机算法混过了 &rpar;

    Hamming Distance Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others) ...

  5. S2SH整合

    Struts2.Spring.Hibernate三大框架在一个项目中的具体职责分配如下: 三大框架整合,导入各个框架和整合所需的包(本项目采用的是Struts2.3+spring3.0+hiberna ...

  6. Java8学习&lpar;3&rpar;- Lambda 表达式

    猪脚:以下内容参考<Java 8 in Action> 本次学习内容: Lambda 基本模式 环绕执行模式 函数式接口,类型推断 方法引用 Lambda 复合 上一篇Java8学习(2) ...

  7. MySQL中&comma; 如何查询某一天&comma; 某一月&comma; 某一年的数据&period;

    今天 select * from 表名 where to_days(时间字段名) = to_days(now()); 昨天(包括昨天和今天的数据) SELECT * FROM 表名 WHERE TO_ ...

  8. Mybatis事务(三)事务工厂

    在前面一篇博客Mybatis事务(一)事务管理方式中我们提到,mybatis及spring提供了三个事务实现类:JdbcTransaction.ManagedTransaction和SpringMan ...

  9. Java装箱的 &quot&semi; &equals;&equals; &quot&semi; 的问题

    装箱和拆箱  packagecom.xzj.Test; ​ /* * @ author thisxzj * @ create 2019-02-25 10:56 */ publicclassBase{  ...

  10. python面向对象编程练习

    练习题 1.面向对象三大特性,各有什么用处,说说你的理解. 面向对象的三大特性: 1.继承:解决代码的复用性问题 2.封装:对数据属性严格控制,隔离复杂度 3.多态性:增加程序的灵活性与可扩展性 2. ...