并查集(找爸爸)

既然要讲解并查集那么首先得明白并查集的概念吧,还有他的用处吧,那么最为正常的,我们试图了解什么叫做并查。

 并查集的作用一般是用来合并一些不想交的集合,以及查找一些特定的结点的父节点。
下面设置一个集合,用来存储点集中和自己这个点相关的点的数组下标。比如设置这个数组为per[100],那么例如2这个节点的父节点就是per[2]=?比如是3,就是说这个点和3是相连的,有关系的,哒哒哒,那么你就相当于把两个有关系的点合在了一起啊,这样就减少了这个点集中的元素的总类的个数喽。一旦重复这个操作那么就可以将这个点集,也就是这个图分成不同的部分,这些不同的部分呢,也是有名字的,它们叫做连通分支,那么这个数组最后含有的数字的种类就是这个图的连通分支数啦,是不是很神奇啊,是啊,这么帅的算法真是漂亮啊
那么看看代码的书写吧:
int Find(int b,int per[])
{
    int x,y,z;
x=b;
    while(x!=per[x])
      {
         x=per[x];
      }
     y=b;
    while(x!=per[y])
      {
         z=per[y];
         per[y]=x;
         y=z;
      }
return x;
}
以上就是并查集中的查找操作,细心的客观显然发现了呀,这里面还含有的是路径压缩,就是将一条线上的所有的点都之间连接到根节点上,这回使得以后的查找操作的时间复杂度边为o(1)。对了,还没有讲解查找的原理呢,先将我们设置好的数组进行初始化,先使得所有的数组元素都变成自己,也就是说开始的时候所有的点的父节点都是自己,然后通过输入边来改变这个数组中的关系,例如输入1-》2这条边,那么就让通过查找来一步步的接近一个父节点,一直到per[i]=i,就结束。
还有一个合并函数join()
代码如下:
void join(int a,int b)
{
   int Fx,Fy;
    Fx=Find(a,per);Fy=Find(b,per);
    if(Fx!=Fy)
       {
          per[Fx]=Fy;
       }
}
原理就是通过查找函数,找出这两个点的最终的父节点,如果相同则不进行操作,如果不相同那么就将其中一个点的父节点变成另一个点的父节点。
看看看,是不是很简单啊,看过之后是不是豁然开朗啊。哈哈
 
end。。。。
还有加上一段最最详细的博文,哈哈
http://blog.csdn.net/dellaserss/article/details/7724401/

转载于:https://www.cnblogs.com/yewa/p/7243520.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
查集(Disjoint Set)是一种数据结构,用于解决集合的合并和查问题。在Python中可以使用类来实现并查集。引用展示了一个简单的并查集类的代码实现,其中包括了初始化集合、查集合、合并集合和判断两个元素是否在同一个集合中的方法。另外,引用和展示了对并查集代码的优化,包括路径压缩和按秩合并等技巧,以提高并查集的效率。 在Python中使用并查集可以解决一些实际问题,如求解岛屿个数、朋友圈等。通过将问题转化为集合的合并和查操作,可以使用并查集来高效地解决这些问题。 所以,如果你需要在Python中实现并查集,可以参考以上的代码实现和优化方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [python 数据结构与算法——并查集](https://blog.csdn.net/itnerd/article/details/103916115)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [并查集Python版](https://blog.csdn.net/XZ2585458279/article/details/127274576)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值