并查集模板类

cpp 复制代码
// 并查集模板
class UnionFind {
public:
    vector<int> parent;
    vector<int> size;
    int n;
    // 当前连通分量数目
    int setCount;
    
public:
    UnionFind(int _n): n(_n), setCount(_n), parent(_n), size(_n, 1) {
        iota(parent.begin(), parent.end(), 0);
    }
    
    int findset(int x) {
        return parent[x] == x ? x : parent[x] = findset(parent[x]);
    }
    
    bool unite(int x, int y) {
        x = findset(x);
        y = findset(y);
        if (x == y) {
            return false;
        }
        if (size[x] < size[y]) {
            swap(x, y);
        }
        parent[y] = x;
        size[x] += size[y];
        --setCount;
        return true;
    }
    
    bool connected(int x, int y) {
        x = findset(x);
        y = findset(y);
        return x == y;
    }
};

在这个模板中,有以下几个主要函数:

  1. UnionFind(int _n): 构造函数,用于初始化并查集,参数 _n 表示元素的个数。
  2. findset(int x): 查找元素 x 所属的集合的代表元素,这里使用了路径压缩的优化,可以减小查询时间。
  3. unite(int x, int y): 合并元素 xy 所属的集合,即将它们连接起来。如果 xy 已经在同一个集合中,则返回 false;否则返回 true,表示合并成功。
  4. connected(int x, int y): 判断元素 xy 是否属于同一个集合,即它们是否连接在一起。
cpp 复制代码
//用法
UnionFind uf(n);//初始化一个n个元素的并查集
uf.unite(x,y);//合并x和y这两个元素
uf.connected(x,y);//判断x和y这两个元素是否在同一个连通块
相关推荐
Kita~Ikuyo4 分钟前
基础数学:图论与信息论
python·算法·llm·图论
三次拒绝王俊凯6 分钟前
数据结构day05
数据结构
烟锁池塘柳017 分钟前
【数学建模】(智能优化算法)粒子群优化算法(PSO)详解与Python实现
算法·数学建模
快乐老干妈28 分钟前
STL-list链表
c++·链表·list
长沙红胖子Qt1 小时前
GStreamer开发笔记(二):GStreamer在ubnutn平台部署安装,测试gstreamer/cheese/ffmpeg/fmplayer打摄像头延迟
c++·开源·产品
西岭千秋雪_1 小时前
Sentinel核心算法解析の滑动窗口算法
分布式·算法·spring cloud·微服务·中间件·sentinel
Qiu的博客1 小时前
一文读懂 AI
人工智能·算法·开源
Murphy_lx1 小时前
排序(1)
数据结构·算法·排序算法
菜树人1 小时前
c/c++ 使用libgeotiff读取全球高程数据ETOPO
c语言·c++
追逐☞1 小时前
机器学习(5)——支持向量机
算法·机器学习·支持向量机