并查集
概念
并查集是一种树型的数据结构,用于处理一些不相交集合的合并及查询问题(即所谓的并、查)。比如说,我们可以用并查集来判断一个森林中有几棵树、某个节点是否属于某棵树等。
实现属性: pre[]:记录每个结点的先驱结点 size[]:记录当前结点所属集合的大小 count:记录连通分量的个数 方法: 查找代表元(find):查找当前结点所属集合的代表元,树形结构,我们可以通过pre逐层向上查找,一直找到根节点即为当前集合的代表元。 (这里的代表元就是一个集合中的代表元素,如果两个元素的代表元相同,则这两个元素属于同一集合)
int find(int x)
{
if (pre[x] == x)
return x;
return pre[x] = find(pre[x]);
}
合并(connect):合并两个结点,我们通过pre[y]=x,将y结点连接到x上,这里我们为了减少find函数的迭代次数,我们总是把小的集合连接到大的集合上。
bool connect(int x, int y)
{
x = find(x);
y = find(y);
if (x == y)
return false;
if (size[x]
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?