C++算法库中的并查集实现

发布时间:2024-08-13 13:09:28 作者:小樊
来源:亿速云 阅读:82

在C++中,可以通过以下方式实现并查集(Disjoint Set):

#include <vector>

class DisjointSet {
public:
    DisjointSet(int n) {
        parent.resize(n);
        rank.resize(n, 0);
        for (int i = 0; i < n; ++i) {
            parent[i] = i;
        }
    }

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

    void merge(int u, int v) {
        int pu = find(u);
        int pv = find(v);
        if (pu != pv) {
            if (rank[pu] < rank[pv]) {
                parent[pu] = pv;
            } else if (rank[pu] > rank[pv]) {
                parent[pv] = pu;
            } else {
                parent[pu] = pv;
                rank[pv]++;
            }
        }
    }

private:
    std::vector<int> parent;
    std::vector<int> rank;
};

使用示例:

#include <iostream>

int main() {
    DisjointSet ds(5);

    ds.merge(0, 1);
    ds.merge(1, 2);
    ds.merge(3, 4);

    std::cout << ds.find(2) << std::endl; // Output: 0
    std::cout << ds.find(4) << std::endl; // Output: 3

    return 0;
}

在上面的示例中,定义了一个DisjointSet类,包含了find和merge两个方法,分别用于查找元素所在的集合和合并两个集合。可以根据实际需求进行修改和扩展。

推荐阅读:
  1. vscode怎样解决c++找不到头文件
  2. windows下vscode找不到c++头文件的解决方法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++

上一篇:数值计算库算法在物理模拟中的表现

下一篇:C++算法库高效选择

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》