- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构部分课后习题答案
第四章
4.1
v2
v0
v1
v3
v4
广度优先生成树(黑体加粗边):
v2
v0
v1
v3
v4
深度拓扑排序序列:v0-v2-v3-v1-v4
4.2
4.3、 如图所示为一个有6个顶点{u1,u2,u3,u4,u5,u6}的带权有向图的邻接矩阵。
根据此邻接矩阵画出相应的带权有向图,利用dijkstra算法求第一个顶点u1到其余各顶点的最短路径,并给出计算过程。
带权有向图:
U1到其他点的最短路径:
S
顶点{ U4 }{ U2,U4 }{ U2,U4,U5 } { U2,U4,U5,U6}U277U3∞∞∞3827U42U5∞1413U660171717最短路径U1,U4U1,U2U1,U2,U5U1,U4,U6U1,U4,U6,U3新顶点U4U2U5U6U3路径长度27131727
4.4证明在图中边权为负时Dijkstra算法不能正确运行
若允许边上带有负权值,有可能出现当与S(已求得最短路径的顶点集,归入S内的结点的最短路径不再变更)内某点(记为a)以负边相连的点(记为b)确定其最短路径时,它的最短路径长度加上这条负边的权值结果小于a原先确定的最短路径长度,而此时a在Dijkstra算法下是无法更新的。
4.5
P.198 图中的权值有负值不会影响prim和kruskal的正确性
如图:
KRUSKAL求解过程:
4.6 Dijkstra算法如何应用到无向图?
答:Dijkstra算法通常是运用在带非负权值的有向图中,但是无向图其实就是两点之间两条有向边权值相同的特殊的有向图,这样就能将Dijkstra算法运用到无向图中。
4.7
用FLOYD算法求出任意两顶点的最短路径(如图A(6)所示)。
A(0)=?A(1)=?A(2)=?A(3)=?A(4)=?A(5)=?A(6)=
V1到V2、V3、V4、V5、V6往返路径长度分别为5,9,5,9,9,最长为9,总的往返路程为37
同理V2到V1、V3、V4、V5、V6分别为5,8,4,4,13,最长为13,总和34
V3对应分别为9,8,12,8,9,最长为12,总和为46
V4对应分别为5,4,12,4,9,最长为12,总和为34
V5对应分别为9,4,8,4,9,最长为9,总和为34
V6对应分别为9,13,9,9,9,最长为13,总和为49
题目要求娱乐中心???距其它各结点的最长往返路程最短”,结点V1, V5最长往返路径最短都是9。按“相同条件下总的往返路径越短越好”,选顶点V5,总的往返路径是34。
4.8
iabcdefghw最早016342413392252最晚02924373113392252
iabcdefghwi-a1a2a3a4aa5ba6a7ca8a9da10ea11fa12a13a14ga15ha16a17w
a1a2a3a4a5a6a7a8a9a10a11a12a13a14a15a16a17最早000016633424131313392222最晚281803292431334731201336392240
关键路径为(i,c,f,h,g,w)
文档评论(0)