数据结构学习笔记-并查集

"查"操作:确定一个指定元素所属集合。

"并"操作:将两个不相交的集合并为一个。

1.用双亲表示法实现并查集

cpp 复制代码
#define SIZE 13
int UFSets[SIZE];    //集合元素数组

//初始化并查集
void Initial(int S[]){
    for(int i=0;i<SIZE;i++)
        S[i]=-1;
}

//Find "查"操作,找x所属集合(返回x所属根结点)
int Find(int S[],int x){
    while(S[x]>=0)    //循环寻找x的根
        x=S[X];
    return x;    //根的S[]小于0
}

//Union "并"操作,将两个集合合并为一个
void Union(int S[],int Root1,int Root2){
    //要求Root1与Root2是不同的集合
    if(Root1==Root2)
        return;
    //将根Root2连接到另一根Root1下面
    S[Root2]=Root1;
}

2.Union操作的优化

①用根结点的绝对值表示树的结点总数

②Union操作,让小树合并到大树

cpp 复制代码
//Union "并"操作,小树合并到大树
void Union(int S[],int Root1,int Root2){
    if(Root1==Root2)
        return;
    if(S[Root2]>S[Root1]){    //Root2结点数更少
        S[Root1]+=S[Root2];    //累加结点总数
        S[Root2]=Root1;    //小树合并到大树
    }
    else{
        S[Root2]+=S[Root1];    //累加结点总数
        S[Root1]=Root2;    //小树合并到大树
    }
}

3.Find操作的优化(压缩路径)

先找到根结点,再将查找路径上所有结点都挂到根结点下。

cpp 复制代码
//Find "查"操作优化,先找到根结点,再进行"压缩路径"
int Find(int S[],int x){
    int root = x;
    while(S[root]>=0)
        root=S[root];    //循环找到根
    while(x!=root){    //压缩路径
        int t=S[x];    //t指向x的父节点
        S[x]=root;    //x直接挂到根结点下
        x=t;
    }
    return root;    //返回根结点编号
}
相关推荐
LuminousCPP5 分钟前
C 语言系列终章|编译与链接 + 预处理
c语言·经验分享·笔记·预处理·编译链接
.千余6 分钟前
【C++】 String 常用操作:增删查改 | 查找 | 截取 | IO
java·服务器·开发语言·c++·笔记·学习
xian_wwq8 分钟前
【学习笔记】「大模型安全:攻击面演化史」第 04 篇-模型窃取与供应链安全
笔记·学习·ai安全
十月的皮皮8 分钟前
C语言学习笔记20260607-判断一个数是否为2的n次方(三种方法)
c语言·笔记·学习
tedcloud1239 分钟前
FluentFlyout部署教程:打造更美观的Windows桌面环境
数据库·人工智能·sql·学习·自动化
nashane9 分钟前
HarmonyOS 6学习:指南针“文图反向”Bug修复——从“北偏东”变“北偏西”的坐标系纠错
学习·华为·bug·harmonyos
一只齐刘海的猫21 分钟前
【Leetcode】三数之和
数据结构·算法·leetcode
lightqjx22 分钟前
【算法】数据结构_扩展域并查集
数据结构·算法·并查集·扩展域并查集
San813_LDD24 分钟前
[量化]《多线程数据同步精讲:std::mutex 的底层原理与最佳实践》
c语言·数据结构
sheeta199831 分钟前
LeetCode 补拙笔记 日期:2026.06.07 题目:49. 字母异位词分组
笔记·算法·leetcode