并查集模板类

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这两个元素是否在同一个连通块
相关推荐
练习时长一年2 分钟前
LeetCode热题100(最小栈)
java·算法·leetcode
vi1212316 分钟前
土壤与水分遥感反演技术综述:原理、方法与应用
人工智能·算法·无人机
智者知已应修善业19 分钟前
【蓝桥杯龟兔赛跑】2024-2-12
c语言·c++·经验分享·笔记·算法·职场和发展·蓝桥杯
Tisfy25 分钟前
LeetCode 955.删列造序 II:模拟(O(mn)) + 提前退出
算法·leetcode·字符串·题解·遍历
im_AMBER30 分钟前
Leetcode 82 每个字符最多出现两次的最长子字符串 | 删掉一个元素以后全为 1 的最长子数组
c++·笔记·学习·算法·leetcode
CHPCWWHSU33 分钟前
CesiumforUnreal环境准备
c++·cesium·unreal·osg
编程大师哥34 分钟前
Boost C++
java·c++·php
java修仙传34 分钟前
力扣hot100:旋转排序数组中找目标值
算法·leetcode·职场和发展
式51636 分钟前
量子力学基础(二)狄拉克符号与复数向量空间
人工智能·算法·机器学习
k***92161 小时前
【Linux】进程概念(六):地址空间核心机制
linux·运维·算法