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

平面點的曼哈頓最小生成樹

引言

作者閱讀并研究了由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)撰寫的論文《Efficient minimum spanning tree construction without Delaunay triangulation》,現將一些收獲體會總結如下。

 

問題描述

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

如果在任意兩個點之間都連一條邊,邊的權值等于兩點的曼哈頓距離,那么這個題目就是標準的最小生成樹問題。一個包含n個點n2條邊的圖,求最小生成樹的代價是O(n2)。但是這種一般性的做法沒有考慮到平面的性質。下面將通過分析最小生成樹的性質和平面性質的結合,得到一個O(nlogn)的算法。

 

最小生成樹的環切性質

先拋開平面,我們考慮一般的離散圖的最小生成樹有什么性質。

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

證明:

假設e(eE)G的一個環C上,并且是環上的權最大邊。

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

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

因為G’G的子圖,所以T’也是G’的最小生成樹。而TT’的權和相等(都是G的最小生成樹)。

證畢。

 

區域分類法

通過最小生成樹的環切性質,我們可以發現有很多邊是沒有用的。如果圖中存在一個環,那么就至少能刪掉一條邊而保持最小生成樹不變。

我們回到平面問題?;舅悸愤€是構建一個離散圖——但是這個圖的邊數必須遠遠小于n2。換句話說我們要想辦法利用環切性質,只保留一些有用的邊。

考察某個點s。我們從s發出8條射線將平面均分成八個部分:

如果點落在射線上,按如下方法劃分:

實線上的點屬于這個區域、虛線上的點不屬于。上圖中p, q都屬于該區域。

下面我們證明:在每個區域里面,s只要和至多一個點連邊即可。

八個扇形區域是對稱的,我們只考慮R1

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

x≥0,

y>x.

考察R1里面兩個點pq,不失一般性設xp≤xq。

1.       yp≤yq

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

|SP|=xp+yp

|SQ|=xq+yq

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

可見當yp≤yq時,|PQ|不是三角形SPQ的最長邊。(在曼哈頓距離下的最長

2.       yp>y

0≤xp≤xq≤yq<yp

|PQ|=xq-xp+yp-yq

|SP|=xp+yp

|SQ|=xq+yq

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

因為xq≤yq,所以|PQ|≤yp-xp≤yp≤xp+yp=|SP|

也就是說,當yp>yq時,|PQ|仍然不是三角形SPQ的最長邊。(曼哈頓距離意義下的最長

綜上,|PQ|無論如何也不可能是三角形SPQ的最長邊。即:在環<s, p, q>中,最大邊只可能是|SP||SQ|。根據環切性質,我們把|SP||SQ|中的較長邊刪除即可。

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

所謂距離s最近的點,實際上就是xk+yk最小的點。

 

圖的構建方法

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

sR1區域內離s最近的點,實際上就是找sR1區域內x+y最小的點。

我們把所有的點按照x從小到大排序:x1≤x2≤…≤xn。

建立一個抽象數據結構T。T中的每個元素對應平面上的一個點(x,y),該元素的第一關鍵字等于y-x,第二關鍵字等于y+x。

PnP1逐個處理每個點。處理Pk的時候,令Pk+1, Pk+2, …, Pn都已經存入到T中。某個點Q(x,y)如果落在PkR1區間內,必須滿足:

1.       x≥xk

2.       y-x>yk-xk

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

要滿足第二個條件,QT中的第一關鍵字必須大于yk-xk(定值)

因為我們要使得|PkQ|最小,所以我們實際上就是:從T的第一關鍵字大于某常數的所有元素中,尋找第二關鍵字最小的元素。

很明顯,T可以用平衡二叉樹來實現。按照第一關鍵字有序來建立平衡樹,對于平衡樹每個節點都記錄以其為根的子樹中第二關鍵字最小的是哪個元素。查詢、插入的時間復雜度都是O(logn)。

平衡二叉樹也可以用線段樹代替。

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

經過上面的處理,我們就把每個點在R1區域內的最近點求出來了。同樣的處理R2, R3, …, R8即可把整個離散圖構建出來。

 

一點優化

如果把R1, R2, …, R8分別處理,則整個算法的復雜度系數過大。

我們很容易注意到,R1R5是對稱的,只要處理其中一個區域即可。根據對稱性,我們只要處理R1, R2, R3, R4這四個區域。

如果點(x,y)PsR1區域內,則:

1.       x≥xk

2.       y-x>yk-xk

如果點(x,y)PsR2區域內,則:

1.       x≥xk

2.       y-x<yk-xk

以上兩組條件僅是一個”>””<”的區別。

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

因而很容易發現,R1R2可以和在一起處理。

這樣我們只要處理R1+R2、R3+R4這兩種情況即可。時間復雜度的常系數從8降低到了2

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

 

總結

這個題目最值得稱道的地方就是“分區域”。“分區域”充分利用了平面性質,結合一般情況下最小生成樹都具有的環切性質,該方法取得了奇效。

我們研究問題的時候也應該注意充分利用已有信息。

posted on 2007-09-27 14:48 Felicia 閱讀(1308) 評論(0)  編輯 收藏 引用 所屬分類: 計算幾何
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产自产女人91一区在线观看| 亚洲精品在线观看视频| 国产精品久久久久国产精品日日 | 欧美亚洲视频一区二区| 国产精品夜夜夜| 久久九九精品99国产精品| 亚洲一区3d动漫同人无遮挡| 国产精品一区二区三区观看| 久久精品一区二区三区不卡牛牛| 亚洲精品偷拍| 国产一区二区三区自拍 | 99亚洲一区二区| 国产欧美另类| 亚洲精品美女| 欧美日韩精品在线观看| 在线亚洲欧美专区二区| 久久成人精品无人区| 亚洲午夜久久久久久久久电影院 | 亚洲国产精品一区二区www| 亚洲激情视频| 国产在线一区二区三区四区| 欧美大胆成人| 欧美精品在线观看91| 麻豆国产精品777777在线| 国产精品久久久久秋霞鲁丝| 欧美激情性爽国产精品17p| 国产精品爽黄69| 亚洲欧美一区二区三区在线| 亚洲无线一线二线三线区别av| 久久综合色播五月| 久久精品99国产精品日本 | 午夜精品福利在线| 欧美日韩福利| 免费亚洲婷婷| 中国成人在线视频| 欧美高潮视频| 亚洲精品日韩在线| 欧美亚洲成人精品| 亚洲精品乱码久久久久久久久| 欧美日本不卡高清| 欧美电影专区| 国产在线播精品第三| 亚洲一区二区精品| 99精品欧美一区| 久久人人爽人人爽| 欧美成人国产一区二区| 国产麻豆成人精品| 亚洲一区二区三区精品在线 | 欧美另类一区二区三区| 亚洲欧美日韩精品久久久久| 久久久91精品国产一区二区精品| 欧美一级视频免费在线观看| 国产日韩欧美综合精品| 午夜在线视频观看日韩17c| 夜夜嗨av一区二区三区| 欧美精品日日鲁夜夜添| 夜夜嗨av一区二区三区中文字幕| 亚洲激情女人| 欧美三级电影大全| 一区二区日韩精品| 久久噜噜噜精品国产亚洲综合| 国产一区二区三区无遮挡| 欧美成人嫩草网站| 欧美黑人在线观看| 亚洲中午字幕| 国模精品一区二区三区色天香| 蜜桃久久av一区| 尤物网精品视频| 欧美深夜福利| 久久久精品999| 在线视频日本亚洲性| 久久精品导航| 亚洲一二三区视频在线观看| 激情婷婷亚洲| 国产精品每日更新| 久久精品视频免费| 篠田优中文在线播放第一区| 欧美国产日韩二区| 久久aⅴ乱码一区二区三区| 一区二区毛片| 亚洲一区二区三区激情| 亚洲欧洲一区| 亚洲电影视频在线| 伊人久久亚洲美女图片| 国产精品一二一区| 国产欧美 在线欧美| 国产伦精品一区二区三区免费迷| 欧美三级乱人伦电影| 欧美欧美天天天天操| 欧美日本一区二区高清播放视频| 麻豆freexxxx性91精品| 欧美亚洲午夜视频在线观看| 一本久久综合亚洲鲁鲁五月天| 亚洲狠狠丁香婷婷综合久久久| 欧美一区二区三区在线看| 亚洲最新中文字幕| 一区二区av在线| 在线亚洲电影| 亚洲午夜精品网| 欧美亚洲一区在线| 久久精品国产亚洲一区二区三区 | 国产一二精品视频| 国产嫩草一区二区三区在线观看| 国产精品婷婷| 国语自产精品视频在线看8查询8| 99日韩精品| 亚洲伦理在线观看| 欧美一区影院| 欧美精品一区在线发布| 红桃视频国产精品| 亚洲精品小视频| 久久久之久亚州精品露出| 亚洲国产精品久久久| 亚洲婷婷综合色高清在线| 久久一区二区三区av| 国产精品欧美久久| 在线观看欧美精品| 亚洲自拍都市欧美小说| 欧美成人dvd在线视频| 一本色道综合亚洲| 欧美日韩一区综合| 亚洲高清不卡一区| 久久久欧美精品sm网站| 亚洲婷婷综合色高清在线| 免费美女久久99| 精品69视频一区二区三区| 亚洲视频日本| 日韩午夜在线观看视频| 久久久久久夜| 亚洲图片欧美一区| 欧美一级专区| 亚洲性感激情| 另类综合日韩欧美亚洲| 亚洲性线免费观看视频成熟| 欧美一级久久久久久久大片| 亚洲免费播放| 免费欧美高清视频| 美女被久久久| 国产亚洲激情视频在线| 亚洲精品在线一区二区| 国产日韩精品一区二区浪潮av| 欧美黄色精品| 国产一区二区三区久久久久久久久| 91久久精品久久国产性色也91| 国产精品久久久久久影视| 亚洲国产经典视频| 在线日韩成人| 亚洲伊人网站| 一区二区三区在线免费播放| 久久一区二区三区超碰国产精品| 久久精品主播| 国产精品日韩二区| 亚洲香蕉伊综合在人在线视看| 亚洲天堂久久| 亚洲国产欧美久久| 久久av红桃一区二区小说| 一本色道久久综合亚洲二区三区 | 亚洲伊人第一页| 欧美中文在线免费| 亚洲精品日韩欧美| 欧美综合国产| 欧美一区二区三区在线看| 香蕉成人伊视频在线观看| 激情视频亚洲| 亚洲资源av| 99一区二区| 欧美精品一区二区三区久久久竹菊 | 久久久久久香蕉网| 午夜视频久久久久久| 欧美精品在线免费播放| 久久综合精品国产一区二区三区| 欧美成人精品高清在线播放| 欧美激情片在线观看| 99精品国产99久久久久久福利| 亚洲欧美卡通另类91av| 久久深夜福利| 中文高清一区| 影音先锋另类| 国产精品人成在线观看免费| 中文精品视频一区二区在线观看| 亚洲自啪免费| 国模叶桐国产精品一区| 久久夜精品va视频免费观看| 亚洲毛片在线看| 久久久久亚洲综合| 亚洲人成77777在线观看网| 国产精品白丝黑袜喷水久久久| 午夜一区二区三区不卡视频| 你懂的国产精品永久在线| 亚洲欧美中日韩| 亚洲美女在线一区| 国产亚洲欧美另类中文| 欧美日韩国产美女| 久久午夜电影网| 欧美一级理论片| 国产曰批免费观看久久久| 欧美精品九九| 久久久综合激的五月天| 欧美在线精品免播放器视频| 99国产精品私拍|