- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Prim算法求解过程
一、算法用途:从某给定点开始,求解无向连通加权图G=(V, E, W)的最小生成树T=(VT, ET, WT).
二、算法步骤:
设G=(V, E, W)是无相连通加权图,|V|=n, |E|=m。(要求从v1点开始求解)
Step 1. 令已经落在树中的点集VT={v1}, ET=Φ, 尚未落在树T上的点集~VT=V-VTStep 2. 找集合VT与~VT~VT~VT ~VT∪{e};
Step 3. 当VT=V, ~VTΦ时,算法中止,即得到原图G的一棵最小生成树,再计算WT.
三、例题
求图1的最小生成树。
(从v1点开始)
[解] 解法过程一:图示法。
① v1
VT={v1}, ~VT…, v6}.
②
VT={v1,v2}, ~VT={v3, …, v6}.
③
VT={v1,v2,v3}, ~VT={v4,v5,v6}
④
VT={v1,v2,v3, v5}, ~VT={v4,v6}⑤
VT={v1,v2,v3, v5, v4}, ~VT={v6}
VT={v1,v2,v3, v5, v4, v6}=V, ~VT=ΦVT ~VT VT与~VTv1 v2,v3,v4,v5,v6 (v1,v2) 1 1 2 v1,v2 v3,v4,v5,v6 (v2,v3) 2 3 3 v1,v2,v3 v4,v5,v6 (v3,v5) 1 4 4 v1,v2,v3,v5 v4,v6 (v5,v4) 3 7 5 v1,v2,v3,v5,v4 v6 (v4,v6) 2 9 6 v1,v2,v3,v5,v4,v6 Φ ----- ----- ------ 最终得到G的最小生成树T如下图所示,WT=9.
(注:做此类题目时请选取上述两种过程中的一种规范书写。)
四、思考题:
1. 此算法的最终结果与起始点的选取有没有关系?
2. 起始点相同的情况下,最后结果(最小生成树和WT)会不会不同?
(试从v1开始求图2的最小生成树)
3. 算法中每一步加边时是否需要考虑避免与已经在T中的边回路?为什么?
4. 此算法每一步都是选取VT与~VT~VTVT的点的邻边中权最小的,否则得到的不是最小生成树(例如图2)。
五、Kruskal算法与Prim算法的区别:
求最小生成树
的算法 起始步骤 算法过程 适合范围 时间复杂度 Kruskal算法 最小权的边 (求解者自行选取) 通过每一步选取最短边来找到最小生成树 稀疏图 O(mlogm),
m是图G的边数 规定了算法的起始点 每一步通过选取点集VT和
~VT之间的最短边来进一步更新这两个点集 稠密图 O(n2)
D氏算法求解过程
[例题]试求无向赋权图中v1到v6的最短路径。
解:D氏算法的具体步骤如下表所示:
步骤 永久标号点集P 最近
距离点 最短
距离 D(v2) D(v3) D(v4) D(v5) D(v6) 1 v1 v2 1 1 4 ∞ ∞ ∞ 2 v1, v2 v3 3 1* 3 8 6 ∞ 3 v1, v2, v3 v5 4 1* 3* 8 4 ∞ 4 v1, v2, v3, v5 v4 7 1* 3* 7 4* 10 5 v1, v2, v3, v5, v4 v6 9 1* 3* 7* 4* 9 6 v1, v2, v3, v5, v4, v6 ------ ------ 1* 3* 7* 4* 9* 从而,v6的P标号为9,即v1到v6的最短距离是9.
注:
“最短距离”表示在当前集合T中的最短距离;
“最近距离点”为其相应的结点。
D(vi)表示各结点当前的标号
*表示新加入集合P中的点。
作业、测验题中若有求解最短路径问题时,请画出此表格表明求解过程。
思考题:
最终完成此表后,如何找到从v1出发到某点vi的最短路径?
若在算法过程中某一步出现了两个相等的最短距离值时,选取哪一个加入集合P?
[提示]:可从以下两类问题考虑:
求从v1出发到某点vi的最短距离;
求从v1出发到其它各点的最短距离。
Kruskal算法(避圈法)求解过程
一、算法用途:求解无向连通加权图G=(V, E, W)的最小生成树T=(VT, ET, WT).
二、算法步骤:
设G=(V, E, W)是无相连通加权图,|V|=n, |E|=m。不妨设G中没有环,
否则把所有的环先去掉。
Step 1. 按照边权从小到大的关系,将m条边排序:e1, e2, ..., em;
Step 2. 取e1∈ET,然后依次检查e2, e3, …, em. 若ej(j≥2)与已经在T中的边
不构成回路,则取ej∈ET,否则就舍弃ej;
Step 3. 当VT=V(或|ET|=n-1,或加入任何一条边都产生回路)时,算法中止,即得到原图G的一
您可能关注的文档
- “谈形势,说目标,话责任”大讨论.doc
- 《 断层解剖学》试题.doc
- “转动套筒”工艺与夹具设计专业课程综合设计说明书.doc
- 《操作系统实验指南》进程(线程)同步及死锁.doc
- 《机械设计基础与实践》课程(高职)期末复习题与答案.doc
- 《机械设计基础》课程学习指导书.doc
- 《计算机操作系统》复习题.doc
- 《空间解析几何》教学指南.doc
- 《铰链四杆机构的曲柄存在条件》教学设计.doc
- 《神经调节的方式》医学课件.doc
- 建筑工程安全保证体系与措施.pdf
- 第七章 运动和力 小专题(三) 速度的图像及计算 沪粤版物理八年级下册.pptx
- 专题02 氮与社会可持续发展 高一化学下学期期中考点(苏教版2019必修第二册).pptx
- 第三单元学习项目一+多样的复调(第一课时)课件++2025-2026学年人教版(简谱)初中音乐八年级上册.pptx
- 1.5 科学验证:机械能守恒定律 课件高一下学期物理鲁科版(2019)必修第二册.pptx
- 第三单元第3课《制陶》课件+2025-2026学年辽海版初中美术八年级上册.pptx
- 9.2 把握适度原则 高二政治课件(统编版选择性必修3).pptx
- 25秋同步导学化学九下粤教科学版教学资源9.4 化学与健康.docx
- 专题2 物质的变化-中考化学复习(人教版2024).pptx
- 15小虾课件-三年级下册语文统编版.pptx
原创力文档


文档评论(0)