并查集(入门篇)

并查集是一种树型的数据结构,用于处理一些不相交集合的合并问题。
并查集的主要操作有:
1-合并两个不相交集合
2-判断两个元素是否属于同一个集合
3-路径压缩

判断元素是否属于同一集合:
由此用某个元素所在树的根结点表示该元素所在的集合
判断两个元素时候属于同一个集合的时候,只需要判断他们所在树的根结点是否一样即可
也就是说,当我们合并两个集合的时候,只需要在两个根结点之间连边即可

路径压缩
上述的做法是指就是将元素的父亲结点指来指去的在指,当这课树是链的时候,可见判断两个元素是否属于同一集合需要O(N)的时间,于是路径压缩产生了作用
路径压缩实际上是在找完根结点之后,在递归回来的时候顺便把路径上元素的父亲指针都指向根结点

找根节点程序
int getfather (int v)
{
if (!father[v]) return v;
father[v]=getfather(father[v]);
return father[v];
}

合并程序
bool union(int x,int y)
{
int fx,fy;
fx=getfather(x);
fy=getfather(y);
father[fx]=fy;
}
(union为保留字!!!)

判断是否在同一集合(同一根节点)

bool judge(int x,int y)
{
int fx,fy;
fx=getfather(x);
fy=getfather(y);
return (fx==fy);
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值