并查集
来源:互联网 发布:女的网络歌手有哪些 编辑:程序博客网 时间:2024/06/07 17:38
并查集:(union-find sets)是一种简单的用途广泛的集合. 并查集是若干个不相交集合,能够实现较快的合并和判断元素所在集合的操作,应用很多,其中最完美的应用是实现Kruskar算法求最小生成树。其实,这一部分《算法导论》讲的很精炼(第21章:用于不相交的集合)。
并查集是一种可以方便地进行以下三种操作的数据结构:合并两个集合;将一元素并入另一集体;判断两个元素是否属于同一个集合。
一般采取树形结构来存储并查集,在合并操作时可以利用树的节点数(加权规则)或者利用一个rank数组来存储集合的深度下界--启发式函数,在查找操作时进行路径压缩使后续的查找操作加速。具体的细节算法导论讲的非常详细。
一下是并查集最基本的实现:
//初始化x集合
void make_set(int x)
{
p[x]=x;
rank[x]=0;
}
//查找x所在的集合
int find_set(int x)
{
if(p[x]!=x)
p[x]=find_set(p[x]);
return p[x];
}
//合并x,y所在的集合,用到路径压缩,按秩合并
void Union(int x,int y)
{
x=find_set(x);
y=find_set(y);
if(rank[x]>rank[y])
p[y]=x;
else if(rank[x]<rank[y])
p[x]=y;
else if(rank[x]==rank[y])
{
p[x]=y;
rank[y]++;
}
}
并查集是一种可以方便地进行以下三种操作的数据结构:合并两个集合;将一元素并入另一集体;判断两个元素是否属于同一个集合。
一般采取树形结构来存储并查集,在合并操作时可以利用树的节点数(加权规则)或者利用一个rank数组来存储集合的深度下界--启发式函数,在查找操作时进行路径压缩使后续的查找操作加速。具体的细节算法导论讲的非常详细。
一下是并查集最基本的实现:
//初始化x集合
void make_set(int x)
{
p[x]=x;
rank[x]=0;
}
//查找x所在的集合
int find_set(int x)
{
if(p[x]!=x)
p[x]=find_set(p[x]);
return p[x];
}
//合并x,y所在的集合,用到路径压缩,按秩合并
void Union(int x,int y)
{
x=find_set(x);
y=find_set(y);
if(rank[x]>rank[y])
p[y]=x;
else if(rank[x]<rank[y])
p[x]=y;
else if(rank[x]==rank[y])
{
p[x]=y;
rank[y]++;
}
}
0 0
- HDU3938 并查集 并查集
- 并查集(集并查)
- HDU1232 并查集<并>
- 并查集
- 数据结构-并查集
- 并查集
- 并查集!
- 并查集
- 并查集
- 并查集
- 并查集
- 并查集总结
- 并查集学习
- 并查集
- 并查集
- 并查集
- 所谓并查集
- 并查集
- jquery总结
- Linux内核中的常用宏container_of其实很简单
- ORACLE 操作 CLOB 字段
- 使用Ant打包部署STAF插件
- 5种提高SQL性能的方法
- 并查集
- 接口与设计模式
- 关于typedef的用法总结
- 边框scrollTop offsetTop 详解
- 詩經UL.KUOPIGN甲骨文信息顯相:國風(國即大學).鵲巢(邦即國家)
- 二叉树中的那些常见的面试题
- Ajax load()方法
- 为什么宏INT_MIN要写成-2147483647-1
- NOJ 比赛成绩查询问题II hash_map