青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

平面點(diǎn)的曼哈頓最小生成樹(shù)

引言

作者閱讀并研究了由Hai Zhou (Electrical and Computer Engineering, Northwestern University, Evanston, IL 60208, USA)Narendra ShenoyWilliam Nicholls (Advanced Technology Group, Synopsys, Inc., Mountain View, CA 94043, USA)撰寫(xiě)的論文《Efficient minimum spanning tree construction without Delaunay triangulation》,現(xiàn)將一些收獲體會(huì)總結(jié)如下。

 

問(wèn)題描述

平面上有n個(gè)不重合的點(diǎn),你的任務(wù)是求這些點(diǎn)的最小生成樹(shù)。兩個(gè)點(diǎn)(x0,y0)(x1,y1)之間的距離定義為|x0-x1|+|y0-y1|。(即曼哈頓距離)

如果在任意兩個(gè)點(diǎn)之間都連一條邊,邊的權(quán)值等于兩點(diǎn)的曼哈頓距離,那么這個(gè)題目就是標(biāo)準(zhǔn)的最小生成樹(shù)問(wèn)題。一個(gè)包含n個(gè)點(diǎn)n2條邊的圖,求最小生成樹(shù)的代價(jià)是O(n2)。但是這種一般性的做法沒(méi)有考慮到平面的性質(zhì)。下面將通過(guò)分析最小生成樹(shù)的性質(zhì)和平面性質(zhì)的結(jié)合,得到一個(gè)O(nlogn)的算法。

 

最小生成樹(shù)的環(huán)切性質(zhì)

先拋開(kāi)平面,我們考慮一般的離散圖的最小生成樹(shù)有什么性質(zhì)。

環(huán)切性質(zhì) 在圖G=(V,E)中,如果存在一個(gè)環(huán),把環(huán)中權(quán)最大的邊e刪除得到圖G’=(V,E\{e})(如果有多條最大邊,則刪除任意一條),則GG’的最小生成樹(shù)權(quán)和相同。

證明:

假設(shè)e(eE)G的一個(gè)環(huán)C上,并且是環(huán)上的權(quán)最大邊。

假設(shè)G的某棵最小生成樹(shù)T包含了e,考慮e連接的兩個(gè)點(diǎn)uv。把eT中刪除,就把T分成兩個(gè)連通分量,u,v分處不同的連通分量。在環(huán)C上對(duì)應(yīng)的把e刪除,從uv還是有一條通路,并且通路上的所有邊權(quán)值都不大于e的權(quán)值;假設(shè)這條通路是(u, x1, x2, …, xL, v)

在點(diǎn)集S={u, x1, x2, …, xL, v}中,和u屬于同一個(gè)集合的點(diǎn)稱(chēng)之為紅點(diǎn),和v屬于同一個(gè)集合的稱(chēng)之為藍(lán)點(diǎn)。顯然S中至少有一個(gè)紅點(diǎn)(u)、至少有一個(gè)藍(lán)點(diǎn)(v)。所以在序列(u, x1, x2, …, xL, v)中必然存在相鄰的兩個(gè)點(diǎn)顏色不同,不妨設(shè)為ab。將<a,b>加入到被刪除了eT中,就得到了一棵新的生成樹(shù)T’:即T’=(T\{e}){<a,b>}。前面提到了通路(u, x1, x2, …, xL, v)中任意一條邊都不大于e,所以<a,b>的權(quán)不大于e的權(quán)。即T’也是G的一棵最小生成樹(shù)。

因?yàn)?/span>G’G的子圖,所以T’也是G’的最小生成樹(shù)。而TT’的權(quán)和相等(都是G的最小生成樹(shù))。

證畢。

 

區(qū)域分類(lèi)法

通過(guò)最小生成樹(shù)的環(huán)切性質(zhì),我們可以發(fā)現(xiàn)有很多邊是沒(méi)有用的。如果圖中存在一個(gè)環(huán),那么就至少能刪掉一條邊而保持最小生成樹(shù)不變。

我們回到平面問(wèn)題。基本思路還是構(gòu)建一個(gè)離散圖——但是這個(gè)圖的邊數(shù)必須遠(yuǎn)遠(yuǎn)小于n2。換句話說(shuō)我們要想辦法利用環(huán)切性質(zhì),只保留一些有用的邊。

考察某個(gè)點(diǎn)s。我們從s發(fā)出8條射線將平面均分成八個(gè)部分:

如果點(diǎn)落在射線上,按如下方法劃分:

實(shí)線上的點(diǎn)屬于這個(gè)區(qū)域、虛線上的點(diǎn)不屬于。上圖中p, q都屬于該區(qū)域。

下面我們證明:在每個(gè)區(qū)域里面,s只要和至多一個(gè)點(diǎn)連邊即可。

八個(gè)扇形區(qū)域是對(duì)稱(chēng)的,我們只考慮R1

s看作原點(diǎn),R1里面的點(diǎn)(x,y)都滿(mǎn)足:

x≥0,

y>x.

考察R1里面兩個(gè)點(diǎn)pq,不失一般性設(shè)xp≤xq

1.       yp≤yq

|PQ|=xq+yq-(xp+xq)

|SP|=xp+yp

|SQ|=xq+yq

所以|PQ|=|SQ|-|SP|≤|SQ|

可見(jiàn)當(dāng)yp≤yq時(shí),|PQ|不是三角形SPQ的最長(zhǎng)邊。(在曼哈頓距離下的最長(zhǎng)

2.       yp>y

0≤xp≤xq≤yq<yp

|PQ|=xq-xp+yp-yq

|SP|=xp+yp

|SQ|=xq+yq

|PQ|= (yp-xp)+(xq-yq)

因?yàn)?/span>xq≤yq,所以|PQ|≤yp-xp≤yp≤xp+yp=|SP|

也就是說(shuō),當(dāng)yp>yq時(shí),|PQ|仍然不是三角形SPQ的最長(zhǎng)邊。(曼哈頓距離意義下的最長(zhǎng)

綜上,|PQ|無(wú)論如何也不可能是三角形SPQ的最長(zhǎng)邊。即:在環(huán)<s, p, q>中,最大邊只可能是|SP||SQ|。根據(jù)環(huán)切性質(zhì),我們把|SP||SQ|中的較長(zhǎng)邊刪除即可。

假設(shè)R1里面有m個(gè)頂點(diǎn):P1, P2, …, Pm,假設(shè)距離s最近的點(diǎn)是Pk,那么只要在SPk之間連邊即可。

所謂距離s最近的點(diǎn),實(shí)際上就是xk+yk最小的點(diǎn)

 

圖的構(gòu)建方法

按照上一節(jié)介紹的方法,我們可以構(gòu)建出一個(gè)至多含有8n條邊的圖。可是如何構(gòu)造呢?如果對(duì)于每個(gè)點(diǎn)s,把所有的點(diǎn)都判斷一次取最小值,那么復(fù)雜度是O(n2),沒(méi)有任何意義。下面我們考慮設(shè)計(jì)一個(gè)高效的算法,實(shí)現(xiàn)找到每個(gè)點(diǎn)的R1區(qū)域內(nèi),離其最近的點(diǎn)的操作。

sR1區(qū)域內(nèi)離s最近的點(diǎn),實(shí)際上就是找sR1區(qū)域內(nèi)x+y最小的點(diǎn)。

我們把所有的點(diǎn)按照x從小到大排序:x1≤x2≤…≤xn

建立一個(gè)抽象數(shù)據(jù)結(jié)構(gòu)TT中的每個(gè)元素對(duì)應(yīng)平面上的一個(gè)點(diǎn)(x,y),該元素的第一關(guān)鍵字等于y-x,第二關(guān)鍵字等于y+x

PnP1逐個(gè)處理每個(gè)點(diǎn)。處理Pk的時(shí)候,令Pk+1, Pk+2, …, Pn都已經(jīng)存入到T中。某個(gè)點(diǎn)Q(x,y)如果落在PkR1區(qū)間內(nèi),必須滿(mǎn)足:

1.       x≥xk

2.       y-x>yk-xk

要滿(mǎn)足第一個(gè)條件,Q必須屬于集合{Pk+1, Pk+2, …, Pn},即Q必然在T中。

要滿(mǎn)足第二個(gè)條件,QT中的第一關(guān)鍵字必須大于yk-xk(定值)

因?yàn)槲覀円沟?/span>|PkQ|最小,所以我們實(shí)際上就是:從T的第一關(guān)鍵字大于某常數(shù)的所有元素中,尋找第二關(guān)鍵字最小的元素。

很明顯,T可以用平衡二叉樹(shù)來(lái)實(shí)現(xiàn)。按照第一關(guān)鍵字有序來(lái)建立平衡樹(shù),對(duì)于平衡樹(shù)每個(gè)節(jié)點(diǎn)都記錄以其為根的子樹(shù)中第二關(guān)鍵字最小的是哪個(gè)元素。查詢(xún)、插入的時(shí)間復(fù)雜度都是O(logn)

平衡二叉樹(shù)也可以用線段樹(shù)代替。

對(duì)于Pk,找到符合上述條件并使|PkQ|最小的Q之后,在PkQ之間連一條邊,并將Pk插入T;繼續(xù)處理Pk-1(除非k=1)

經(jīng)過(guò)上面的處理,我們就把每個(gè)點(diǎn)在R1區(qū)域內(nèi)的最近點(diǎn)求出來(lái)了。同樣的處理R2, R3, …, R8即可把整個(gè)離散圖構(gòu)建出來(lái)。

 

一點(diǎn)優(yōu)化

如果把R1, R2, …, R8分別處理,則整個(gè)算法的復(fù)雜度系數(shù)過(guò)大。

我們很容易注意到,R1R5是對(duì)稱(chēng)的,只要處理其中一個(gè)區(qū)域即可。根據(jù)對(duì)稱(chēng)性,我們只要處理R1, R2, R3, R4這四個(gè)區(qū)域。

如果點(diǎn)(x,y)PsR1區(qū)域內(nèi),則:

1.       x≥xk

2.       y-x>yk-xk

如果點(diǎn)(x,y)PsR2區(qū)域內(nèi),則:

1.       x≥xk

2.       y-x<yk-xk

以上兩組條件僅是一個(gè)”>””<”的區(qū)別。

處理R1的時(shí)候,任意時(shí)刻處理Pk,我們希望找T中第一關(guān)鍵字大于某常數(shù)的第二關(guān)鍵字最小元素;處理R2的時(shí)候,任意時(shí)刻處理Pk,我們要找的就是T中第一關(guān)鍵字小于某常數(shù)的第二關(guān)鍵字最小元素。

因而很容易發(fā)現(xiàn),R1R2可以和在一起處理。

這樣我們只要處理R1+R2R3+R4這兩種情況即可。時(shí)間復(fù)雜度的常系數(shù)從8降低到了2

我們按照這樣的方法建立的離散圖至多含有8n條邊。對(duì)該圖求最小生成樹(shù)的時(shí)間復(fù)雜度為O(nlogn);之前建圖的復(fù)雜度也是O(nlogn),所以總時(shí)間復(fù)雜度O(nlogn)。空間復(fù)雜度O(n)

 

總結(jié)

這個(gè)題目最值得稱(chēng)道的地方就是“分區(qū)域”。“分區(qū)域”充分利用了平面性質(zhì),結(jié)合一般情況下最小生成樹(shù)都具有的環(huán)切性質(zhì),該方法取得了奇效。

我們研究問(wèn)題的時(shí)候也應(yīng)該注意充分利用已有信息。

posted on 2007-09-27 14:48 Felicia 閱讀(1308) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 計(jì)算幾何
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            99av国产精品欲麻豆| 久久蜜臀精品av| 1024亚洲| 久久一区二区三区av| 亚洲欧美在线磁力| 亚洲小视频在线观看| 欧美日韩国产精品| 久久精品免费播放| 久久精品亚洲一区| 久久国产免费看| 久久激情综合| 久久婷婷久久一区二区三区| 欧美xart系列高清| 欧美在线免费观看视频| 国产欧美日本在线| 欧美国产日韩二区| 欧美电影美腿模特1979在线看 | 国产一区二区三区四区| 亚洲小视频在线| 中文精品99久久国产香蕉| 亚洲一区二区黄色| 国产欧美激情| 国产精品国产一区二区| 亚洲国产日韩在线一区模特| 亚洲国产成人在线视频| 欧美激情一区二区三区在线视频观看| 久久一区激情| 一区二区免费在线视频| 欧美在线视频一区| 久久麻豆一区二区| 91久久精品一区二区三区| 亚洲欧美日韩综合国产aⅴ| 国产麻豆91精品| 欧美在线亚洲综合一区| 久久综合伊人77777蜜臀| 99re亚洲国产精品| 亚洲欧美日韩第一区| 久久国产色av| 欧美黄网免费在线观看| 欧美另类女人| 国产精品拍天天在线| 免费日本视频一区| 欧美视频在线观看一区二区| 免费亚洲一区二区| 欧美日韩日日夜夜| 在线看欧美视频| 亚洲一区三区视频在线观看| 国产精品系列在线| 原创国产精品91| 午夜伦理片一区| 亚洲大片免费看| 亚洲国产天堂久久综合| 欧美国产一区在线| 欧美日韩精品伦理作品在线免费观看| 国产精品毛片在线看| 欧美好吊妞视频| 国产精品久久久久久久久久久久久 | 亚洲高清资源| 中文亚洲欧美| 蜜桃av一区二区在线观看| 欧美在线免费播放| 亚洲精品女av网站| 欧美亚洲综合在线| 欧美日韩在线视频首页| 欧美精品日本| 精品51国产黑色丝袜高跟鞋| 欧美一区二区高清| 欧美激情视频给我| 亚洲国产91精品在线观看| 国产欧美一区二区三区在线看蜜臀| 欧美国产日产韩国视频| 久久一区激情| 国内精品**久久毛片app| 国产精品综合网站| 亚洲在线视频网站| 亚洲激情小视频| 欧美成人免费在线| 亚洲激情网站免费观看| 亚洲区一区二区三区| 亚洲国产欧美一区二区三区同亚洲 | 香蕉尹人综合在线观看| 亚洲免费一级电影| 欧美日韩免费一区二区三区视频 | 亚洲永久在线| 国产精品成人av性教育| 欧美视频免费在线观看| 国产精品你懂的在线| 你懂的视频一区二区| 欧美精品一区在线观看| 亚洲欧美日韩一区二区| 欧美专区日韩专区| 激情国产一区| 久久精品免费| 久久精品国产亚洲5555| 欧美国产日韩免费| 亚洲日本久久| 99综合视频| 国产日产欧美一区| 黄色成人av网站| 麻豆亚洲精品| 欧美另类在线观看| 日韩视频永久免费| 欧美a级片一区| 国产精品福利在线观看| 久久久亚洲影院你懂的| 亚洲欧美日韩精品一区二区| 亚洲黑丝一区二区| 欧美一区二区日韩| 国产精品一区二区欧美| 亚洲日本在线观看| 亚洲人永久免费| 国产精品视频专区| 欧美综合国产精品久久丁香| 国产精品日日做人人爱| 亚洲视频图片小说| 国产精品视频xxx| 久久久久久久激情视频| 欧美高潮视频| 狠狠色狠狠色综合日日tαg| 亚洲一区二区三区四区五区黄| 久久国产精品毛片| 国产精品福利在线观看| 99精品视频免费观看视频| 亚洲精品小视频在线观看| 欧美日韩中字| 国产精品啊啊啊| 在线视频日本亚洲性| 欧美区在线观看| 欧美一区二区黄色| 一区二区三区不卡视频在线观看 | 亚洲一级免费视频| 久久国产综合精品| 亚洲在线观看免费视频| 国产精品hd| 欧美日韩色婷婷| 午夜精品久久久久影视| 国产自产在线视频一区| 欧美.com| 亚洲福利专区| 欧美成人自拍| 亚洲国产一二三| 麻豆精品国产91久久久久久| 久久国产综合精品| 日韩亚洲视频| 亚洲欧美在线aaa| 欧美在线视频网站| 欧美性猛片xxxx免费看久爱| 看欧美日韩国产| 亚洲午夜免费福利视频| 久久精品一区二区国产| 欧美成人小视频| 亚洲欧美日韩精品久久久久| 亚洲高清久久网| 亚洲男人的天堂在线aⅴ视频| 国内精品视频一区| 香蕉免费一区二区三区在线观看| 欧美日韩在线免费观看| 亚洲精品在线三区| 亚洲精品乱码久久久久久蜜桃麻豆 | 欧美香蕉视频| 怡红院精品视频| 久久久精品国产免大香伊| 狠狠色2019综合网| 国产精品久久久对白| 欧美二区在线看| 国产欧美日韩不卡| 亚洲三级色网| 亚洲狠狠丁香婷婷综合久久久| 欧美自拍丝袜亚洲| 欧美一区二区三区日韩| 久久久www| 亚洲国产精品嫩草影院| 亚洲欧美日韩国产一区二区| 亚洲国产成人av在线 | 亚洲午夜影视影院在线观看| 亚洲高清色综合| 欧美日韩视频不卡| 欧美韩日亚洲| 欧美日韩视频一区二区三区| 欧美a级片网| 久久久久国产精品午夜一区| 欧美在线国产| 韩日欧美一区二区| 亚洲色诱最新| 国产区日韩欧美| 久久久久久久久久久一区 | 欧美阿v一级看视频| 亚洲午夜伦理| 性欧美1819sex性高清| 欧美亚洲日本网站| 一区二区三区欧美| 久久综合伊人77777麻豆| 久久国产综合精品| 欧美精品综合| 欧美jizz19性欧美| 国产毛片一区二区| 在线一区免费观看| 在线观看日韩av| 99精品久久免费看蜜臀剧情介绍| 欧美在线视频观看|