并查集模板

简介: 并查集模板

并查集


概念

并查集是一种简单的集合表示,支持2种操作:


1.查找集合S中元素x所在子集合,并返回子集合名字。

2.把集合S中子集合root2并入子集合root1,要求2集合互不相交。


通常用森林的双亲作为并查集的存储结构,每个集合以一棵树表示。



模板

#include <iostream>
#include <vector>
using namespace std;
typedef int ElementType;
struct Set
{
    ElementType data;
    int parent;
};
// 查找某个元素所在集合(用根结点表示)
int Find(vector<Set> &S, ElementType x)
{
    int i;
    for (i = 0; i < S.size() && S[i].data != x; i++)
    {
        ;
    }
    if (i >= S.size())
    {
        return -1;
    }
    for (; S[i].parent >= 0; i = S[i].parent)
    {
        ;
    }
    return i;
}
// 集合并操作
void Union(vector<Set> &S, ElementType x1, ElementType x2)
{
    int root1, root2;
    root1 = Find(S, x1);
    root2 = Find(S, x2);
    if (root1 != root2)
    {
        S[root2].parent = root1;
    }
}
int main()
{
    vector<Set> S(10);
    // Parent
    // -1 0 -1 0 2 -1 0 2 5 5
    for (int i = 0; i < 10; i++)
    {
        S[i].data = i + 1;
        int tmp;
        cin >> tmp;
        S[i].parent = tmp;
    }
    Union(S, 10, 5);
    for (auto it : S)
    {
        cout << it.data << " " << it.parent << endl;
    }
    system("pause");
    return 0;
}
目录
相关文章
|
C语言 Python
python学习之21天挑战赛(1)
学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。各位小伙伴,如果您:
133 0
python学习之21天挑战赛(1)
|
6天前
|
弹性计算 人工智能 安全
云上十五年——「弹性计算十五周年」系列客户故事(第二期)
阿里云弹性计算十五年深耕,以第九代ECS g9i实例引领算力革新。携手海尔三翼鸟、小鹏汽车、微帧科技等企业,实现性能跃升与成本优化,赋能AI、物联网、智能驾驶等前沿场景,共绘云端增长新图景。
|
12天前
|
存储 弹性计算 人工智能
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
2025年9月24日,阿里云弹性计算团队多位产品、技术专家及服务器团队技术专家共同在【2025云栖大会】现场带来了《通用计算产品发布与行业实践》的专场论坛,本论坛聚焦弹性计算多款通用算力产品发布。同时,ECS云服务器安全能力、资源售卖模式、计算AI助手等用户体验关键环节也宣布升级,让用云更简单、更智能。海尔三翼鸟云服务负责人刘建锋先生作为特邀嘉宾,莅临现场分享了关于阿里云ECS g9i推动AIoT平台的场景落地实践。
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
|
4天前
|
云安全 人工智能 安全
Dify平台集成阿里云AI安全护栏,构建AI Runtime安全防线
阿里云 AI 安全护栏加入Dify平台,打造可信赖的 AI
|
11天前
|
人工智能 自然语言处理 自动驾驶
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
|
7天前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
637 17
|
6天前
|
人工智能 Java Nacos
基于 Spring AI Alibaba + Nacos 的分布式 Multi-Agent 构建指南
本文将针对 Spring AI Alibaba + Nacos 的分布式多智能体构建方案展开介绍,同时结合 Demo 说明快速开发方法与实际效果。
427 34