博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
并查集(找爸爸)
阅读量:5905 次
发布时间:2019-06-19

本文共 1060 字,大约阅读时间需要 3 分钟。

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

 并查集的作用一般是用来合并一些不想交的集合,以及查找一些特定的结点的父节点。
下面设置一个集合,用来存储点集中和自己这个点相关的点的数组下标。比如设置这个数组为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

你可能感兴趣的文章
查找(AVL平衡二叉树)
查看>>
AJAX-初学AJAX本地环境配置
查看>>
【精选】Nginx负载均衡学习笔记(一)实现HTTP负载均衡和TCP负载均衡(官方和OpenResty两种负载配置)...
查看>>
Linux常用基本命令( rmdir, rm, mv )
查看>>
POJ2406 Power Strings(KMP)
查看>>
JavaScript-console的使用_016
查看>>
两种方式设置iframe的高度区别
查看>>
Iterator 和 for...of 循环
查看>>
关于iOS 11.x微信连wifi流程中,在Portal页无法拉起微信问题的简单记录
查看>>
Python GUI库wxPython官网Hello World示例的逐行解释
查看>>
RE·WORK 巅峰对话:深度学习将彻底改变医疗健康领域
查看>>
Codeforces Round #442 (Div. 2) A B
查看>>
极值问题(acms)
查看>>
swift UI专项训练8 展示数据
查看>>
openstacks
查看>>
PHP5下单独编译php模块
查看>>
字体图标学习
查看>>
局域网网速变慢的故障细致分析
查看>>
虚拟桌面带宽评估
查看>>
一起学shell(十一)之安全的shell脚本:起点
查看>>