并查集模板

并查集學(xué)習(xí)可查看網(wǎng)站

class Djset {
public:
    vector<int> parent;  // 記錄節(jié)點(diǎn)的根
    vector<int> rank;  // 記錄根節(jié)點(diǎn)的深度(用于優(yōu)化)
    Djset(int n): parent(vector<int>(n)), rank(vector<int>(n)) {
        for (int i = 0; i < n; i++) {
            parent[i] = i;
        }
    }

    int find(int x) {
        if (x != parent[x]) {
            parent[x] = find(parent[x]);
        }
        return parent[x];
    }

    bool merge(int x, int y) {
        int rootx = find(x);
        int rooty = find(y);
        if (rootx != rooty) {
            if (rank[rootx] < rank[rooty]) {
                swap(rootx, rooty);
            }
            parent[rooty] = rootx;
            if (rank[rootx] == rank[rooty]) rank[rootx] += 1;
            return false; // 根節(jié)點(diǎn)不同,返回false
        }
        // 根節(jié)點(diǎn)相同,返回true
        return true;
    }
};

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 并查集詳解 ——圖文解說,簡單易懂(轉(zhuǎn))https://blog.csdn.net/liujian20150808...
    yunfeichen119閱讀 184評(píng)論 0 0
  • 用兩張圖告訴你,為什么你的 App 會(huì)卡頓? - Android - 掘金 Cover 有什么料? 從這篇文章中你...
    hw1212閱讀 14,118評(píng)論 2 59
  • 問題介紹:并查集一般用來解決連通性方面的問題,最典型的比如圖的連通性,與鄰接表配合最佳連通這個(gè)概念抽象出來的特點(diǎn)是...
    FF_b0bf閱讀 918評(píng)論 0 2
  • 以PAT甲級(jí)1114為例,寫了個(gè)并查集模板,記錄下來。題目就不列了,感興趣去官網(wǎng)找一下
    MambaHJ閱讀 241評(píng)論 0 1
  • 久違的晴天,家長會(huì)。 家長大會(huì)開好到教室時(shí),離放學(xué)已經(jīng)沒多少時(shí)間了。班主任說已經(jīng)安排了三個(gè)家長分享經(jīng)驗(yàn)。 放學(xué)鈴聲...
    飄雪兒5閱讀 7,868評(píng)論 16 22

友情鏈接更多精彩內(nèi)容