亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

[模版] K/最近鄰匹配(KD Tree)

2019-11-10 19:05:21
字體:
來源:轉載
供稿:網友

nth_element相當于快排的split/choose pivot過程

2D 最近

#include <bits/stdc++.h>#define mem(a,b) memset(a,b,sizeof(a))const int INF=0x3f3f3f3f;const int maxn=1e5+50;typedef long long ll;using namespace std;int cmpNo;struct Node{ int x[2],l,r,id; bool Operator <(const Node &b)const{ return x[cmpNo]<b.x[cmpNo]; }};ll calDis(Node &l,Node &r){ ll dx=l.x[0]-r.x[0],dy=l.x[1]-r.x[1]; return dx*dx+dy*dy;}Node p[maxn];int Build(int l,int r,int d){ if(l>r)return 0; cmpNo=d; int mid=l+r>>1; nth_element(p+l,p+mid,p+r+1); p[mid].l=Build(l,mid-1,1-d); p[mid].r=Build(mid+1,r,1-d); return mid;}ll ansDist;int ansId;void Kth(int l,int r,Node &tar,int d){ if(l>r)return; int mid=l+r>>1; if(p[mid].id!=tar.id){ ll tmp=calDis(p[mid],tar); if(tmp<ansDist){ ansDist=tmp; ansId=p[mid].id; } } long long t=tar.x[d]-p[mid].x[d]; if(t<=0){ Kth(l,mid-1,tar,1-d); if(ansDist>t*t) Kth(mid+1,r,tar,1-d); } else{ Kth(mid+1,r,tar,1-d); if(ansDist>t*t) Kth(l,mid-1,tar,1-d); }}Node a[maxn];int main(){ int T; scanf("%d",&T); for(int cs=1;cs<=T;cs++) { int n; scanf("%d",&n); for(int i=1;i<=n;i++){ scanf("%d %d",&p[i].x[0],&p[i].x[1]); p[i].id=i; a[i]=p[i]; } Build(1,n,0); for(int i=1;i<=n;i++) { ansDist=1e18; Kth(1,n,a[i],0); K維 Q近#include <bits/stdc++.h>#define mem(a,b) memset(a,b,sizeof(a))const int INF=0x3f3f3f3f;const int maxn=4e5+50;typedef long long ll;using namespace std;int cmpNo;const int K=2;struct Node{ int x[K],l,r,id; bool operator <(const Node &b)const{ return x[cmpNo]<b.x[cmpNo]; }};long long Dis(const Node &a,const Node &b){ long long ret=0; for(int i=0;i<K;i++) ret+=(a.x[i]-b.x[i])*(a.x[i]-b.x[i]); return ret;}Node p[maxn];int Build(int l,int r,int d){ if(l>r)return 0; cmpNo=d; int mid=l+r>>1; nth_element(p+l,p+mid,p+r+1); p[mid].l=Build(l,mid-1,(d+1)%K); p[mid].r=Build(mid+1,r,(d+1)%K); return mid;}priority_queue<pair<ll,int> >q;void Kth(int l,int r,Node tar,int k,int d){ if(l>r)return; int mid=l+r>>1; if(p[mid].id!=tar.id){ pair<ll,int>v=make_pair(Dis(p[mid],tar),p[mid].id); if(q.size()==k && v<q.top())q.pop(); if(q.size()<k)q.push(v); } ll t=tar.x[d]-p[mid].x[d]; if(t<=0){ Kth(l,mid-1,tar,k,(d+1)%K); if(q.top().first>t*t) Kth(mid+1,r,tar,k,(d+1)%K); } else{ Kth(mid+1,r,tar,k,(d+1)%K); if(q.top().first>t*t) Kth(l,mid-1,tar,k,(d+1)%K); }}Node a[maxn];ll calDis(Node &l,Node &r){ ll dx=l.x[0]-r.x[0],dy=l.x[1]-r.x[1]; return dx*dx+dy*dy;}const int Q=2;int main(){ int T; scanf("%d",&T); for(int cs=1;cs<=T;cs++) { int n; scanf("%d",&n); for(int i=1;i<=n;i++){ scanf("%d %d",&p[i].x[0],&p[i].x[1]); p[i].id=i; a[i]=p[i]; } Build(1,n,0); for(int i=1;i<=n;i++) { while(!q.empty()) q.pop(); for(int j=0;j<Q;j++) q.push(make_pair(1e18,-1)); Kth(1,n,a[i],Q,0); while(!q.empty()){ printf("%lld/n",calDis(a[i],a[q.top().second])); q.pop(); } } } return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区三区在线免费观看| 久久精品福利视频| 亚洲国产免费av| 国产中文字幕亚洲| 国产丝袜一区视频在线观看| 欧美亚洲激情在线| 国产精品免费视频久久久| 亚洲视频自拍偷拍| 操日韩av在线电影| 国产精品久久久久久久久久久久久| 中文字幕日韩专区| 少妇久久久久久| 国产精品老牛影院在线观看| 亚洲精品女av网站| 日韩成人在线视频网站| 91a在线视频| 26uuu另类亚洲欧美日本老年| 欧美性视频在线| www.xxxx欧美| 欧美又大粗又爽又黄大片视频| 国产免费一区视频观看免费| 2018中文字幕一区二区三区| 欧美多人爱爱视频网站| 成人免费网站在线看| 亚洲人精品午夜在线观看| 欧美日韩在线一区| 亚洲国产成人在线播放| 亚洲国产精品一区二区三区| 久久综合久久美利坚合众国| 久久成人av网站| 日韩最新中文字幕电影免费看| 国产69久久精品成人| 午夜精品一区二区三区av| 日韩视频免费看| 日本道色综合久久影院| 91亚洲永久免费精品| 97高清免费视频| 夜夜嗨av一区二区三区免费区| 高清欧美性猛交xxxx黑人猛交| 欧美贵妇videos办公室| 136fldh精品导航福利| 欧美日韩在线观看视频小说| 国产丝袜精品视频| 久久久免费观看视频| 欧美大人香蕉在线| 久久视频在线看| xxx成人少妇69| 亚洲热线99精品视频| 精品美女久久久久久免费| 亚洲国产日韩欧美综合久久| 国产精品九九久久久久久久| 欧美日韩激情美女| 69久久夜色精品国产69乱青草| 国产亚洲精品久久久久动| 国产福利精品视频| 亚洲免费成人av电影| 国产91成人video| 欧美激情亚洲精品| 日韩小视频在线观看| 亚洲人成电影网站| 在线亚洲午夜片av大片| 精品成人国产在线观看男人呻吟| 亚洲精品456在线播放狼人| 68精品久久久久久欧美| 国产亚洲精品一区二区| 亚洲国产精品免费| 亚洲色图av在线| 亚洲一级一级97网| 亚洲最新视频在线| 欧洲成人午夜免费大片| 91精品久久久久久久久| 国产精品久久电影观看| 96pao国产成视频永久免费| 欧美亚洲另类制服自拍| 亚洲成人网在线观看| 亚洲成av人乱码色午夜| 国产亚洲精品一区二555| 欧美极品xxxx| 国产精品中文字幕在线观看| 国产精品羞羞答答| 国产精品久久久久久影视| 国产99久久精品一区二区 夜夜躁日日躁| 久久6免费高清热精品| 日韩亚洲综合在线| 福利视频导航一区| 成人444kkkk在线观看| 国产成人在线一区| 精品中文字幕视频| 成人伊人精品色xxxx视频| 久久免费精品日本久久中文字幕| 成人亚洲综合色就1024| 亚洲欧美日韩高清| 欧美日韩加勒比精品一区| 色妞在线综合亚洲欧美| 国产欧美日韩免费| 中文字幕精品一区二区精品| 国产69精品久久久久99| 国产91热爆ts人妖在线| 国产精品三级美女白浆呻吟| 55夜色66夜色国产精品视频| 韩国一区二区电影| 国产精品久久久久久中文字| 欧洲亚洲在线视频| 亚洲深夜福利网站| 欧美日韩加勒比精品一区| 国产成人a亚洲精品| 日韩av在线网页| 久久久久久久成人| 成人妇女免费播放久久久| 亚洲黄一区二区| 97超级碰碰碰久久久| 91九色在线视频| 98精品在线视频| 亚洲成色777777在线观看影院| 午夜精品久久久久久久久久久久久| 538国产精品一区二区在线| 亚洲天堂一区二区三区| 日韩av免费观影| 这里只有精品视频| 欧美性xxxx极品高清hd直播| 国产精品自拍网| 久久综合久中文字幕青草| 亚洲高清av在线| 久久精品最新地址| 搡老女人一区二区三区视频tv| 日韩av网址在线观看| 国产精品色视频| 国产91av在线| 国产成人精彩在线视频九色| 成人福利在线观看| 成人午夜在线观看| 国产精品视频yy9099| 欧美猛男性生活免费| 国产亚洲xxx| 深夜福利国产精品| 欧美精品福利在线| 亚洲成人av片在线观看| 精品国产一区二区三区久久| 日韩福利视频在线观看| 国产91色在线免费| 色悠悠国产精品| 国产成人精品最新| 伊人伊人伊人久久| 国产色婷婷国产综合在线理论片a| 久久久av免费| 亚洲精品久久久一区二区三区| 亚洲国产又黄又爽女人高潮的| 国产亚洲精品久久久久久牛牛| 91沈先生在线观看| 久久国产精品久久国产精品| 午夜精品久久久久久久久久久久久| 成人免费网视频| 欧美裸体xxxx极品少妇软件| 久久91精品国产91久久久| 国产亚洲精品久久久优势| 在线视频中文亚洲| 日韩中文字幕在线免费观看| 亚洲欧洲视频在线| 久久伊人精品一区二区三区| 精品久久久久久中文字幕大豆网| 91在线观看欧美日韩| 久久精品国产成人| 国产精品美女无圣光视频| 91成品人片a无限观看|