日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

并查集(Union-Find-Set)简洁而高效地处理连通分量的查询与合并

發(fā)布時間:2024/10/6 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 并查集(Union-Find-Set)简洁而高效地处理连通分量的查询与合并 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

并查集(Union-Find-Set)簡潔而高效地處理連通分量的查詢與合并

并查集由一個整型數(shù)組和兩個函數(shù)構(gòu)成

1.數(shù)組pre[]:記錄每個結(jié)點的前導(dǎo)結(jié)點(父節(jié)點),初始化為:pre[i]=i

2.函數(shù)unionset:合并兩個連通分量

3.函數(shù)findset:查找任意兩個點是否在同一個連通分量

可以把每個連通分量看成一個集合,該集合中包含了連通分量中的所有點。

這些點兩兩連通,而具體的連通方式無關(guān)緊要,就好比集合中的元素沒有先后順序之分,只有屬于和不屬于的區(qū)別

在圖中,每個點恰好屬于一個連通分量,對應(yīng)到集合表示中,每個元素恰好屬于一個集合。

換句話說,圖的所有連通分量可以用若干個不相交集合來表示

并查集的精妙之處在于用樹來表示集合。例如,若包含點1,2,3,4,5,6的圖有3個連通分量{1,3},{2,5,6},{4},

則需要用3棵樹來表示。這三棵樹的具體形態(tài)無關(guān)緊要,只要有一棵樹包含1,3兩個點,一棵樹包含2,5,6三個點,

還有一棵樹包含4這個點即可。規(guī)定每棵樹的根節(jié)點是這棵樹所對應(yīng)的集合的代表元。

并查集中的路徑壓縮,在特殊情況下,這棵樹可能是一條長鏈。設(shè)鏈的最后一個節(jié)點是x,則每次執(zhí)行find(x)都會遍歷整條鏈,

效率十分低下,改進(jìn)方法其實很簡單。既然每棵樹表示的只是一個集合,因此樹的形態(tài)是無關(guān)精要的,并不需要在查找操作之后保持樹的形態(tài)不變,只要順便把遍歷過的節(jié)點都改成樹根的子節(jié)點,下次查找就會快很多

int pre[maxn];//pre[i]記錄i的前驅(qū)節(jié)點 int findset(int x)//查找x的根節(jié)點 {if(pre[x]==x) return x;return pre[x]=findset(pre[x]); } //合并x和y所在的連通分量 void unionset(int x,int y) {int fx=findset(x),fy=findset(y);pre[fy]=fx; }

總結(jié)

以上是生活随笔為你收集整理的并查集(Union-Find-Set)简洁而高效地处理连通分量的查询与合并的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。