并查集是一种比较有用的数据结构,主要是用于解决将一些元素合并和查找元素在某个集合的操作,即union操作和findSet操作。
其中,利用有根树实现并查集的方法是普遍使用的方法,也是效率最优的方法。
在并查集一开始时,每个元素做为一个单独的集合,即每个都是只含有一个根的子树。
在合并的时候,主要是采用按秩合并。在开始时,每个元素的秩为0,随着合并秩发生变化。
其中包括makeSet方法,即初始化集合的方法。我们用p[i]表示元素i所属的集合的祖先(即此集合的标识),用rank[i]表示元素i的秩。
//初始化并查集
void makeset(int i)
{
p[i]=i;
}
接着就是合并操作:
//合并i和j
void union1(int i,int j)
{
link(findSet(i),findSet(j));
}
合并的方法,调用了link方法,link方法主要是根据元素的秩修改元素的集合标识,从而使得元素合并。
//合并工作
void link(int i,int j)
{
if(rank[i]>rank[j])
{
p[i]=p[j];
}
else
{
p[j]=p[i];
if(i==j)
{
rank[j]=rank[j]+1;
}
}
}
可以看到传给link方法的参数是findSet,这是什么方法呢?其实就是寻找元素i的祖先的方法,最终传给link合并的,其实是元素的祖先。故合并其实是祖先合并。
不过,判断元素属于哪个集合,只需用findSet找到它的祖先即可,元素即与其祖先在同一个集合中。
完整的代码如下:
#include<iostream>
#define NMAX 101
using namespace std;
int p[NMAX],rank[NMAX];
//初始化
void init()
{
int i=1;
for(;i<=NMAX-1;i++)
{
p[i]=-1;
rank[i]=0;
}
}
//初始化并查集
void makeset(int i)
{
p[i]=i;
}
//合并工作
void link(int i,int j)
{
if(rank[i]>rank[j])
{
p[i]=p[j];
}
else
{
p[j]=p[i];
if(i==j)
{
rank[j]=rank[j]+1;
}
}
}
//找i的祖先,即集合的代表
int findSet(int i)
{
if(i!=p[i])
{
p[i]=findSet(p[i]);
}
return p[i];
}
//合并i和j
void union1(int i,int j)
{
link(findSet(i),findSet(j));
}
int main()
{
int k;
init();
for(k=1;k<=10;k++)
{
makeset(k);
}
//<1,2>
union1(1,2);
//<3,4>
union1(3,4);
//<2,3>
union1(2,3);
//<6,7>
union1(6,7);
//<5,8>
union1(5,8);
//<9,10>
union1(9,10);
//<8,9>
union1(8,9);
for(k=1;k<=10;k++)
{
printf("%d的集合为%d\n",k,findSet(k));
}
system("pause");
return 0;
}
最终的输出为:
1的集合为1
2的集合为1
3的集合为1
4的集合为1
5的集合为5
6的集合为6
7的集合为6
8的集合为5
9的集合为5
10的集合为5
分享到:
相关推荐
数据结构中的并查集(Disjoint Set)是一种用于处理元素集合的分割问题的数据结构,它主要支持两种操作:合并(union)与查找(find)。在实际应用中,尤其是在算法竞赛(ACM)和图论中,它被广泛用于解决快速查询和...
### 并查集知识点概述 #### 一、并查集定义与基本概念 **并查集**(Union-Find Set)是一种数据结构,用于处理一些不相交集合的合并及查询问题,通常用来解决动态连通性问题。并查集支持两种主要的操作:**并操作*...
并查集是一种在图论和算法设计中常用的离散数学结构,主要用于处理一些不相交集合的合并与查询问题。这个压缩包文件“团伙数据”显然包含了一些与并查集算法相关的练习数据和可能的题解,目的是帮助学习者更好地理解...
综上所述,"并查集入门学习并查集"的资源可能是针对初学者的教程,通过“并查集.pdf”这个文档,你将能够深入理解并查集的基本概念、操作原理以及如何在实际问题中应用。对于希望提升算法能力,尤其是参与ACM竞赛的...
并查集是一种在大型无向图中查找元素所属连通分量的数据结构,常用于解决合并与查询的问题。它的核心思想是将元素组织成一棵树形结构,每个元素都有一个父节点,根节点代表了一个连通分量。并查集的主要操作包括...
并查集,在一些有N个元素的集合应用问题中,我们通常是在开始时让每个元素构成一个单元素的集合,然后按一定顺序将属于同一组的元素所在的集合合并,其间要反复查找一个元素在哪个集合中。这一类问题近几年来反复...
并查集是一种在图论和算法设计中常用的离散数学结构,主要用来处理一些不相交集合的合并与查询问题。在本数据压缩包中,主题聚焦于家谱数据,可以推断出这些数据可能包含了家庭成员之间的关系,通过并查集这种数据...
### 并查集模版详解 #### 一、并查集简介 并查集是一种用于处理元素集合的动态数据结构,常被应用于图论、计算机网络、数据挖掘等领域。其核心功能是支持两种操作:合并两个集合(并操作)与查询某个元素所属的...
并查集是一种在大型无向图中查找连接组件的数据结构,它在计算机科学中有着广泛的应用,尤其是在图论和算法设计中。这个压缩包文件"division"可能包含了一个C++实现并查集的示例代码,特别指出是为Visual Studio ...
并查集是一种数据结构,主要用于处理一些不相交集合的合并与查询问题。在并查集中,我们将一组对象划分为多个不相交的集合,每个集合由一个代表元素标识。这个数据结构支持两种主要操作: 1. **Find** 操作:查询...
并查集是一种用于处理不相交集合操作的数据结构,它主要包含两个基本操作:查找(Find)和合并(Union)。在并查集中,通常用森林的结构来表示各个集合,每棵树代表一个集合,树的根节点代表集合的标识。 **查找...
并查集是一种在大型无向图中查找元素所属集合的数据结构,它主要应用于不经常进行连接,但频繁查询是否属于同一集合的问题。在并查集中,我们通常关注两个操作:`Find` 和 `Union`。`Find` 操作用于确定元素所属的...
并查集是一种在分散的数据元素中寻找连接关系的数据结构,常用于处理一些不相交集合的合并与查询问题。在图论中,它可以帮助我们快速判断两个节点是否属于同一个连通分量,或者将两个连通分量合并。在本教程中,我们...
并查集是一种数据结构,主要用于处理不相交集合的合并与查询问题。它在很多算法竞赛,如信息学奥林匹克竞赛(OI)和全国青少年信息学奥林匹克联赛(NOIP)中有着广泛的应用。朱全民教授的讲解主要围绕并查集的基本...
并查集模板并查集模板并查集模板并查集模板并查集模板并查集模板
并查集是一种用于处理集合合并与查询的抽象数据类型,主要应用于解决连通性问题,例如判断图中的两个节点是否在同一连通分量内。在本解题报告中,我们将探讨并查集算法在PKU(北京大学)的三道题目:PKU1182、PKU...
深入理解并查集算法,细致讲解,专业老师,一步到位 。
并查集是一种在图论和数据结构中广泛使用的算法,主要应用于处理不相交集合的合并与查询。在ACM(国际大学生程序设计竞赛)中,掌握并查集的运用对于解决某些特定类型的问题至关重要。这个压缩包包含了全面的并查集...
### 并查集算法思想详解 #### 一、并查集基本概念 并查集是一种数据结构,主要用于处理一些不交集的合并及查询问题,它支持两种操作: 1. **合并**(Union):将两个不同的集合合并成一个集合。 2. **查找**...
### 并查集C/C++代码实现 #### 知识点概述 并查集是一种用于处理元素集合的动态集合问题的数据结构,它支持两种基本的操作:**并**和**查**。并查集的主要用途是判断一个元素是否属于某个集合,并且能够有效地将两...