BZOJ3053: The Closest M Points
题解:
我们可以事先在堆里放入插入m个inf然后不断的比较当前值与堆首元素的大小,如果小于的话进入。
估计函数也可以随便写写。。。
query的时候貌似不用保留dir。。。
return 0写在 while 里面我也是醉了。。。
不用开long long为什么大家都开了。。。
k-d tree助我进第一版
代码:
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<string>
#define inf 2100000000
#define maxn 100000+5
#define maxm 500+100
#define eps 1e-10
#define ll long long
#define sqr(x) (x)*(x)
#define pa pair<int,int>
#define for0(i,n) for(int i=0;i<=(n);i++)
#define for1(i,n) for(int i=1;i<=(n);i++)
#define for2(i,x,y) for(int i=(x);i<=(y);i++)
#define for3(i,x,y) for(int i=(x);i>=(y);i--)
#define for4(i,x) for(int i=head[x],y;i;i=e[i].next)
#define mod 1000000007
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=*x+ch-'';ch=getchar();}
return x*f;
}
int n,m,rt,cur,ans[];
struct rec
{
int d[],mi[],mx[],l,r;
int& operator[](int x){return d[x];}
}p[maxn],now,t[maxn];
priority_queue<pa>q;
bool operator <(rec a,rec b){return a[cur]<b[cur];}
inline void pushup(int k)
{
int l=t[k].l,r=t[k].r;
for0(i,m-)
{
t[k].mi[i]=min(t[k].mi[i],min(t[l].mi[i],t[r].mi[i]));
t[k].mx[i]=max(t[k].mx[i],max(t[l].mx[i],t[r].mx[i]));
}
}
int build(int l,int r,int dir)
{
int mid=(l+r)>>;
cur=dir;
nth_element(p+l,p+mid,p+r+);
t[mid]=p[mid];
for0(i,m-)t[mid].mx[i]=t[mid].mi[i]=t[mid][i];
t[mid].l=l<mid?build(l,mid-,(dir+)%m):;
t[mid].r=mid<r?build(mid+,r,(dir+)%m):;
pushup(mid);
return mid;
}
inline int dis(rec a,rec b)
{
int ret=;
for0(i,m-)ret+=sqr(a[i]-b[i]);
return ret;
}
inline int calc(int k)
{
if(!k)return inf;
int ret=;
for0(i,m-)if(now[i]<t[k].mi[i])ret+=sqr(t[k].mi[i]-now[i]);
for0(i,m-)if(now[i]>t[k].mx[i])ret+=sqr(now[i]-t[k].mx[i]);
return ret;
}
void query(int k)
{
int dl=calc(t[k].l),dr=calc(t[k].r),d0=dis(t[k],now);
if(d0<q.top().first){q.pop();q.push(pa(d0,k));}
if(dl<dr)
{
if(dl<q.top().first)query(t[k].l);
if(dr<q.top().first)query(t[k].r);
}else
{
if(dr<q.top().first)query(t[k].r);
if(dl<q.top().first)query(t[k].l);
}
}
int main()
{
freopen("input.in","r",stdin);
freopen("output.txt","w",stdout);
for0(i,)t[].mi[i]=inf,t[].mx[i]=-inf;
while(scanf("%d %d",&n,&m)!=EOF)
{
for1(i,n)for0(j,m-)p[i][j]=read();
rt=build(,n,);
int qq=read();
while(qq--)
{
for0(i,m-)now[i]=read();n=read();
printf("the closest %d points are:\n",n);
for1(i,n)q.push(pa(inf,));
query(rt);
for1(i,n)ans[i]=q.top().second,q.pop();
for3(i,n,){for0(j,m-){if(j)printf(" ");printf("%d",t[ans[i]][j]);}printf("\n");}
}
}
return ;
}
BZOJ3053: The Closest M Points的更多相关文章
- 【kd-tree】bzoj3053 The Closest M Points
同p2626.由于K比较小,所以不必用堆. #include<cstdio> #include<cstring> #include<cmath> #include& ...
- BZOJ3053:The Closest M Points(K-D Teee)
Description The course of Software Design and Development Practice is objectionable. ZLC is facing a ...
- 【BZOJ 3053】The Closest M Points
KDTree模板,在m维空间中找最近的k个点,用的是欧几里德距离. 理解了好久,昨晚始终不明白那些“估价函数”,后来才知道分情况讨论,≤k还是=k,在当前这一维度距离过线还是不过线,过线则要继续搜索另 ...
- BZOJ 3053 The Closest M Points
[题目分析] 典型的KD-Tree例题,求k维空间中的最近点对,只需要在判断的过程中加上一个优先队列,就可以了. [代码] #include <cstdio> #include <c ...
- 【BZOJ】3053: The Closest M Points(kdtree)
http://www.lydsy.com/JudgeOnline/problem.php?id=3053 本来是1a的QAQ.... 没看到有多组数据啊.....斯巴达!!!!!!!!!!!!!!!! ...
- 【HDOJ】4347 The Closest M Points
居然是KD解. /* 4347 */ #include <iostream> #include <sstream> #include <string> #inclu ...
- bzoj 3053 HDU 4347 : The Closest M Points kd树
bzoj 3053 HDU 4347 : The Closest M Points kd树 题目大意:求k维空间内某点的前k近的点. 就是一般的kd树,根据实测发现,kd树的两种建树方式,即按照方差 ...
- 数据结构(KD树):HDU 4347 The Closest M Points
The Closest M Points Time Limit: 16000/8000 MS (Java/Others) Memory Limit: 98304/98304 K (Java/Ot ...
- poj:4091:The Closest M Points
poj:4091:The Closest M Points 题目 描写叙述 每到饭点,就又到了一日几度的小L纠结去哪吃饭的时候了.由于有太多太多好吃的地方能够去吃,而小L又比較懒不想走太远,所以小L会 ...
随机推荐
- 跟着PHP100第一季学写一个CMS(1-10)
笔记: 这次用的方法是先跟着视频做一遍,隔一天或半天后独立再做一遍,能发现真正不会的地方记录下来. CMS0.1界面布局1.问题:分两个css来实现时basic.css+index.php出现定位不正 ...
- onclick控制元素显示与隐藏时,点击第一次无反应的原因
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
- Wpf 简单制作自己的窗体样式(2)
上一篇blog讲了制作简单的样式的窗体,对于一个传统的窗体,不仅仅可以拖动,和关闭操作.还具有最大化.最小化.隐藏,以及改变窗体的大小等.这篇blog就是对上篇的补充,完善窗体的改变大小和最大化最小化 ...
- 【非原】c语言之声明和定义的区别
原创地址:http://www.cnblogs.com/haore147/p/3647466.html 什么是定义?什么是声明?它们有何区别? 举个例子: 1 2 A)int i; B)extern ...
- TWaver3D入门探索——3D拓扑图之人在江湖
俗话说,有人的地方就有江湖,江湖就是帮派林立错综复杂的关系网.今天我们就来展示这样一个小小的江湖. 故事背景 崇祯末年,民不聊生,烽烟四起-- 江湖都是有背景的,我们的3D江湖也需要一个背景.江湖就是 ...
- linux学习笔记(3)-文件系统
三大类文件类型 普通文件:包括文本文件.数据文件.可执行的二进制程序文件 目录文件:linux系统把目录看成一种特殊的文件,利用它构成了文件系统的树形结构 设备文件:把设备也看成是一个文件,例如你的鼠 ...
- 【链表】BZOJ 2288: 【POJ Challenge】生日礼物
2288: [POJ Challenge]生日礼物 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 382 Solved: 111[Submit][S ...
- Matlab中sortrows函数解析
一.问题来源 返回检索到的数据(按相关度排序)在原始数据中的索引. 二.问题解析 x = [1 4 3 5; 1 3 2 6]:sortrows(x)其结果是按照row来排列,默认首先排第一列,1和1 ...
- 团体程序设计天梯赛-练习集L2-007. 家庭房产
L2-007. 家庭房产 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 给定每个人的家庭成员和其自己名下的房产,请你统计出每个 ...
- firefly服务器间通信演示
源地址:http://www.9miao.com/question-15-54560.html 最近好多童鞋都在问firefly几个服务器之间是如何通信的,其实在之前的distributed使用文档中 ...