【算法提高班】并查集

關(guān)于并查集的題目不少羡藐,官方給的數(shù)據(jù)是 30 道(截止 2020-02-20),但是有一些題目雖然官方?jīng)]有貼并查集標(biāo)簽悯许,但是使用并查集來說確非常簡單仆嗦。這類題目如果掌握模板,那么刷這種題會(huì)非诚群荆快瘩扼,并且犯錯(cuò)的概率會(huì)大大降低,這就是模板的好處垃僚。

我這里總結(jié)了幾道并查集的題目:

大家可以學(xué)了模板之后去套用一下上面的三道題集绰,做不出來的可以看看我的題解。

并查集概述

并查集算法谆棺,主要是解決圖論中「動(dòng)態(tài)連通性」問題的

Union-Find 算法解決的是圖的動(dòng)態(tài)連通性問題栽燕,這個(gè)算法本身不難,能不能應(yīng)用出來主要是看你抽象問題的能力改淑,是否能夠把原始問題抽象成一個(gè)有關(guān)圖論的問題纫谅。

如果你對(duì)這個(gè)算法不是很明白,推薦看一下這篇文章Union-Find 算法詳解溅固,講的非常詳細(xì)。

你可以把并查集的元素看成部門的人兰珍,幾個(gè)人可以組成一個(gè)部門個(gè)數(shù)侍郭。

并查集核心的三個(gè)方法分別是union, find, connected

  • union: 將兩個(gè)人所在的兩個(gè)部門合并成一個(gè)部門(如果兩個(gè)人是相同部門掠河,實(shí)際山不需要合并)

(圖來自 labuladong)

  • find: 查找某個(gè)人的部門 leader
  • connnected: 判斷兩個(gè)人是否是一個(gè)部門的

(圖來自 labuladong)

模板

這是一個(gè)我經(jīng)常使用的模板亮元,我會(huì)根據(jù)具體題目做細(xì)小的變化,但是大體是不變的唠摹。

class UF:
    parent = {}
    cnt = 0
    def __init__(self, M):
        # 初始化 parent 和 cnt

    def find(self, x):
        while x != self.parent[x]:
            x = self.parent[x]
        return x
    def union(self, p, q):
        if self.connected(p, q): return
        self.parent[self.find(p)] = self.find(q)
        self.cnt -= 1
    def connected(self, p, q):
        return self.find(p) == self.find(q)

如果你想要更好的性能爆捞,這個(gè)模板更適合你,相應(yīng)地代碼稍微有一點(diǎn)復(fù)雜勾拉。

class UF:
    parent = {}
    size = {}
    cnt = 0
    def __init__(self, M):
        # 初始化 parent煮甥,size 和 cnt

    def find(self, x):
        while x != self.parent[x]:
            x = self.parent[x]
            # 路徑壓縮
            self.parent[x] = self.parent[self.parent[x]];
        return x
    def union(self, p, q):
        if self.connected(p, q): return
        # 小的樹掛到大的樹上盗温, 使樹盡量平衡
        leader_p = self.find(p)
        leader_q = self.find(q)
        if self.size[leader_p] < self.size[leader_q]:
            self.parent[leader_p] = leader_q
        else:
            self.parent[leader_q] = leader_p
        self.cnt -= 1
    def connected(self, p, q):
        return self.find(p) == self.find(q)

大家可以根據(jù)情況使用不同的模板。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末成肘,一起剝皮案震驚了整個(gè)濱河市卖局,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌双霍,老刑警劉巖砚偶,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異洒闸,居然都是意外死亡染坯,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門丘逸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來单鹿,“玉大人,你說我怎么就攤上這事鸣个⌒叻矗” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵囤萤,是天一觀的道長昼窗。 經(jīng)常有香客問我,道長涛舍,這世上最難降的妖魔是什么澄惊? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮富雅,結(jié)果婚禮上掸驱,老公的妹妹穿的比我還像新娘。我一直安慰自己没佑,他們只是感情好毕贼,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蛤奢,像睡著了一般鬼癣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上啤贩,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天待秃,我揣著相機(jī)與錄音,去河邊找鬼痹屹。 笑死章郁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的志衍。 我是一名探鬼主播暖庄,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼聊替,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了雄驹?” 一聲冷哼從身側(cè)響起佃牛,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎医舆,沒想到半個(gè)月后俘侠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蔬将,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年爷速,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片霞怀。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惫东,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出毙石,到底是詐尸還是另有隱情廉沮,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布徐矩,位于F島的核電站滞时,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏滤灯。R本人自食惡果不足惜坪稽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鳞骤。 院中可真熱鬧窒百,春花似錦、人聲如沸豫尽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽美旧。三九已至渤滞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間陈症,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國打工震糖, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留录肯,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓吊说,卻偏偏與公主長得像论咏,于是被迫代替她去往敵國和親优炬。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容

  • 關(guān)于并查集的題目不少厅贪,官方給的數(shù)據(jù)是 30 道(截止 2020-02-20)蠢护,但是有一些題目雖然官方?jīng)]有貼并查集標(biāo)...
    fe_lucifer閱讀 217評(píng)論 0 0
  • 關(guān)于并查集的題目不少,官方給的數(shù)據(jù)是 30 道(截止 2020-02-20)养涮,但是有一些題目雖然官方?jīng)]有貼并查集標(biāo)...
    fe_lucifer閱讀 253評(píng)論 0 0
  • “并查集”這部分知識(shí)點(diǎn)講得最清楚的是《算法》(第 4 版)葵硕,本篇“并查集”的介紹是我看這本書第 1.5 節(jié)的學(xué)習(xí)筆...
    李威威閱讀 892評(píng)論 0 2
  • 并查集(Union Find) 需求分析 假設(shè)現(xiàn)在有這樣一個(gè)需求,如下圖的每一個(gè)點(diǎn)代表一個(gè)村莊贯吓,每一條線就代表一條...
    ducktobey閱讀 1,406評(píng)論 0 1
  • 并查集 入門 并查集(union-find set)是一種不算太“低級(jí)”的數(shù)據(jù)結(jié)構(gòu)悄谐,在算法競賽中比較常見介评。簡而言之...
    LittleMagic閱讀 2,997評(píng)論 2 10