- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Kruskal算法的一种改进--二分Kruskal算法
黄荣明
吉林大学软件学院,吉林长春(130012 )
E-mail :tony513513@
摘 要:最小生成树是数据结构中图的一个重要部分,它有许多重要的实际应用。如何方便
快捷地找到最小生成树,具有极其重要的现实经济意义。基于此,本文先简单介绍了Prim
算法,Kruskal算法和Sollin算法等经典算法,并提出了对Kruskal算法改进的新算法,命名为
二分Kruskal算法。同时给出了新算法的基本思想,并论证了此算法是正确可行的。接着给
出了新算法的程序实现,然后对新算法和经典Kruskal算法的理论时间代价和实验时间代价
做了详细的比较。最后得出结论:二分Kruskal算法总体上略快于经典Kruskal算法。
关键词:最小生成树;经典Kruskal算法;二分Kruskal算法
1. 引言
赋以权数的图在实际问题中十分有用.根据不同的实际情况,权数的含意可以各不相
同.例如,可用权数代表两地之间道路的长度或行车时间,也可用权数代表某工序所需的加
工时间等.
对于连通的无向图或强连通的有向图,从任一顶点出发周游,或是对于有根的有向图,
从图的根顶点出发周游,可以访问到所有的顶点。周游时经过的边加上所有顶点构成了图的
一个连通子图,称为图的一棵生成树。
对于网络,其生成树中的边也带权,将生成树各边的权值总和称为生成树的权,并把权
值最小的生成树称为最小生成树(Minimum Spanning Tree,MST) 。
构造最小生成树的依据有两条:[1]
1、在网中选择n -1条边连接网的n个顶点;
2 、尽可能选取权值为最小的边。
2. 最小生成树的应用
最小生成树问题可以直接用于工程和经济运营的实际中去.如管道的铺设、线路的施工、
运输路线的设计等问题中都涉及最小费用问题.例如:
网络G表示n各城市之间的通信线路网线路 (其中顶点表示城市,边表示两 个城市
之间的通信线路,边上的权值表示线路的长度或造价。可通过求该网络的最小生成树达
到求解通信线路或总代价最小的最佳方案。
在生物学研究中,需要对植物和动物分类,对基因进行分类,以获得对种群固有结构
的认识.可以将图论的最小生成树理论引入分子生物学中基因表示数据的聚类分析方
法,设计生成树的表示和基于最小生成树的聚类算法,该方法对研究基因的结构、功
能以及不同种类基因之间的关系都具有重要意义.
3. 经典算法
为了得到最小生成树,人们设计了很多算法,最著名的有Prim算法,Kruskal算法和Sollin算
法。
-1-
3.1 Prim 算法(Prim Algorithm)
设G=(V ,E)是具有n个顶点的网络,T=(U ,TE)为G 的最小生成树,U是T 的顶点集合,
[2]
TE是T 的边集合。Prim算法的基本思想是 :
(1)从集合V 中任取一顶点(例如取顶点v0)放入集合U 中,这时U= {v0},TE=NULL 。
(2 )在所有一个顶点在集合U里,另一个顶点在集合V-U里的边中,找出权最小的
边(u,v)(u ∈U ,v ∈V-U) ,将该边放入TE,并将顶点v加入集合U 。
(3 )重复上述操作直到U=V为止。这时TE 中有n-1条边,T=(U,TE)就是G 的一棵最小生
成树。显然,Prim算法的时间复杂性为O(n2) ,该算法适用于求边稠密网的最小生成树。
3.2 Kruskal 算法(Kruskal Algorithm)
文档评论(0)