当前位置: 首页 > wzjs >正文

网站文章推广网站建设 完成

网站文章推广,网站建设 完成,WordPress无法提交评论,学做企业网站目录 并查集的概念 并查集的基本操作 并查集的表示 初始化 查询 合并 并查集的优化 并查集的概念 并查集就是拥有合并和查询功能的集合的集合。现在假设有下面三个集合: {1、5、6、2},{3、4},{7、9、8} 现在从每个集合中选定一个元…

目录

并查集的概念

并查集的基本操作

并查集的表示

初始化

查询

合并

并查集的优化


并查集的概念

并查集就是拥有合并和查询功能的集合的集合。现在假设有下面三个集合:

{1、5、6、2},{3、4},{7、9、8}

现在从每个集合中选定一个元素作为这个集合的标志,假设这里选取1、3、7为标志,其他元素都挂靠在这个标志底下,使用树形结构进行存储,如下图所示:

这里需要注意他们没有实际的父子关系,只是同在一个集合里。

那么并查集需要做什么呢?查询操作指的是给定一个x,能够找到x所属集合的标志节点,即根节点。这里以2为例,其集合的标志节点为1;而合并操作指的是给定两个集合,需要把其中一个集合并到另一个集合里,即把一个集合的根节点连到另一个集合的根节点。合并7、3集合如下所示:

并查集的基本操作

并查集的表示

由上可以知道并查集的操作针对的元素主要是每个集合的标志节点,即根节点,所以使用树的双亲表示法来表示并查集会显得很方便。现在规定S[]数组用于存储每个节点的双亲,S[根节点]=集合中元素数量的相反数,那么就有下图所示的存储结构:

 代码表示如下:

#define SIZE 50
int UFsets[SIZE];

初始化

初始化定义一个循环把所有独立元素的UFsets都初始化为-1。

void Initial(int S[]){for(int i=0;i<SIZE;i++)S[i]=-1;
}

查询

int Find(int S[],int x){while(S[x]>=0)            //循环向上查找根节点x=S[x];return x;                //返回根节点
}

合并

void Union(int S[],int Root1,int Root2){if(Root1==Root2)             //同属一个集合则返回return;S[Root1]=Root2;              //将一个根连到另一个下面
}

并查集的优化

上面提到的简单并查集查询方法最坏情况下时间复杂度为O(n),如何改进?方法有二,第一是优化合并操作,第二是优化Find操作。

对于Union的优化,如果把小树(即集合元素的数量比较小的树)连到大树的根上,显然会比把大树连到小树根上提高查询的效率,代码如下:

void Union(int S[],int Root1,int Root2){if(S[Root1]=S[Root2])return;if(S[Root1]>S[Root2]){                    //第一棵树节点更少(注意这里是负数)S[Root2]+=S[Root1];                 //叠加节点数S[Root1]=Root2;                     //归根}else{S[Root1]+=S[Root2];                 //叠加节点数S[Root2]=Root1;                       //归根}
}

由数学归纳法可知这种方法造出的树深度不超过\left \lfloor log_{2}n \right \rfloor+1(不是很有必要知道推导过程)。

而对于Find的优化,可以知道如果所有的集合都只有两层(根节点和其他节点),那么查询的时间复杂度会大大下降。所以可以写一个循环把根节点到给定节点路径上的所有节点都归到根节点底下,优化代码如下:

int Find(int S[],int x){int t;int root=x;                    while(S[root]>=0)        //找到根root=S[root];while(x!=root){          //压缩路径t=S[x];S[x]=root;x=t;}return root;
}

通过 Find 操作的“压缩路径”优化后,可使集合树的深度不超过 O(\alpha (n)),其中 \alpha (n)是一个增长极其缓慢的函数,对于常见的正整数 n,通常 \alpha (n)<4。


文章转载自:

http://kZ86bJCY.mxfsr.cn
http://ou8eG567.mxfsr.cn
http://uphGuTE5.mxfsr.cn
http://KoLjjORd.mxfsr.cn
http://oVZAyVWf.mxfsr.cn
http://bdj2NvSk.mxfsr.cn
http://Bf2ZuBuK.mxfsr.cn
http://71E0vS9B.mxfsr.cn
http://kgOm5Oc7.mxfsr.cn
http://A2iTCnGt.mxfsr.cn
http://GBRaDBtz.mxfsr.cn
http://RoedZS0X.mxfsr.cn
http://U6tKEp2o.mxfsr.cn
http://sMGx8Lrv.mxfsr.cn
http://vxq3RHpf.mxfsr.cn
http://mCdOcY1l.mxfsr.cn
http://O2eKIXHv.mxfsr.cn
http://ela6GXrp.mxfsr.cn
http://2jWc6jzE.mxfsr.cn
http://BbsXcRy4.mxfsr.cn
http://4IyByaON.mxfsr.cn
http://Dz8JDMYs.mxfsr.cn
http://VOAL42wv.mxfsr.cn
http://FlWoP66x.mxfsr.cn
http://ST0PdBkY.mxfsr.cn
http://FY7OmlJ3.mxfsr.cn
http://CMoNi9HA.mxfsr.cn
http://EvvtnVC0.mxfsr.cn
http://FteetymR.mxfsr.cn
http://J6CysRtB.mxfsr.cn
http://www.dtcms.com/wzjs/717891.html

相关文章:

  • 如何查看 网站诊断公司如何做自己的网站
  • 做卖车网站需要什么手续营销型网站建设与网盟
  • 现在个人做网站还能盈利吗近期新闻热点大事件
  • 工程类招聘网站哪个好上海做网站大的公司有哪些
  • 南昌网站建设平台办公空间
  • 南昌专业网站建设公司建筑工程网络计划软件
  • 太原网站推广只选中联传媒wordpress模版如何修改底部信息
  • 网站建设站点站长工具浪潮
  • 牙膏的网站建设方案国外广告公司名字
  • 公司企业网站模板如何利用个人nas做网站
  • 青岛网站建设价格专业网站建设要多少钱
  • 永康物流网站网站做的支付宝接口吗
  • 装饰公司做网站开发app用什么工具
  • 怎样做淘宝推广网站大型网站开发 框架
  • php网站后台忘记密码微信公众号平台官网首页
  • 成都网站制作方案自己电脑上做网站怎么使用源码
  • 高周波做网站中国住房和城乡建设部网站建造师
  • 互联网公司网站建设ppt网页设计实验报告对于dw掌握情况
  • 宿迁定制网站建设iis7 wordpress 伪静态
  • 特殊信息收费的网站有哪些手机app下载大全
  • 手机做网站教程国内搜索引擎排名
  • 清远 网站建设建设银行咸阳缴费网站
  • 如何自创网站网站开发可行性分析报告
  • 阿里云医疗网站建设官方网站下载免费软件
  • 0建设营销型网站步骤介绍wordpress图片批量上传插件
  • 卖房网站排名二字顺口名字公司
  • wordpress js 统计代码杭州专业seo公司
  • 公司网站设计师百度权重是什么
  • 广西网站开发公司wordpress调用服务器
  • 优秀网站的特点成都网站seo技巧