- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
武汉纺织大学《数据结构》实验报告3
武汉纺织大学《数据结构》实验报告
班级: 管工类 专业 班 姓名: 序号:
实验时间: 2014 年 5 月 16 日 指导教师:
实验三:图的基本操作与应用
一、实验目的:
1、掌握图的几种主要存储方法及基本操作
2、掌握图的两种遍历方法
3、掌握利用普里姆算法和克鲁斯卡尔算法求取最小生成树的方法
4、掌握求取AOE网关键路径的方法,以实现项目时间管理
二、实验内容:
1、编写程序,输出图的邻接矩阵,输出两种遍历序列,并求出最小生成树。
实验步骤:
①、在Java语言编辑环境中新建程序,输入顶点集合和边集合,构造一个图7-15所示的带权图,可参考书本225页示例程序;
②、对该带权图,进行插入顶点、插入边、删除顶点、删除边操作,并输出操作后的邻接矩阵,可参考书本226-228页示例程序;
③、输出从顶点A开始的深度优先遍历和广度优先遍历的序列,可参考书本238、240页示例程序;
④、输出运用普里姆算法求出的最小生成树,可参考书本245页示例程序。
2、设计一个程序求出完成整项工程至少需要多少时间以及整项工程中的关键活动。④、找出该AOE网的关键路径,并计算出该项目的完成时间。
关键路径相关时间知识点:
设活动ai由弧j,k(即从顶点j到k)表示,其持续时间记为dut(j,k),则:
e(i)=ve(j) l(i)=vl(k)-dut(j,k)
求ve(i)和vl(j)分两步:
(1).从ve(1)=0开始向前递推
ve(j)=Max{ve(i)+dut(i,j)}i,j∈T, 2=j=n ,其中,T是所有以j为弧头的弧的集合。
(2).从vl(n)=ve(n)开始向后递推
vl(i)=Min{vl(j)-dut(i,j)} i,j∈S,1=i=n-1,其中,S是所有以i为弧尾的弧的集合。
求关键路径的算法:输入e条弧j, k,建立AOE网的存储结构;从点出发,令ve[0]=0,按拓扑顺序求其余各顶点的最早发生时间ve[i](1=i=n-1)。如果得到的拓扑有序序列中顶点个数小于网中顶点数n,则说明网中存在环,不能求关键路径,算法终止,否则转到步骤;从点vn出发,令vl[n-1]=ve[n-1],按逆拓扑顺序求其余各顶点的最迟发生时间vl[i](n-2=i=0);④、根据各顶点的ve和vl值,求每条弧s的最早开始时间e(s)和最迟开始时间l(s)。若某弧满足条件e(s)=l(s),则为关键活动。Graph1.java
package Frist;
public class Graph1 {
public static void main(String[] args) {
String[] vertices = { A, B, C, D, E };
Edge edges[] = { new Edge(0, 1, 5), new Edge(0, 3, 2),
new Edge(1, 0, 5), new Edge(1, 2, 7), new Edge(1, 3, 6),
new Edge(2, 1, 7), new Edge(2, 3, 8), new Edge(2, 4, 3),
new Edge(3, 0, 2), new Edge(3, 1, 6), new Edge(3, 2, 8),
new Edge(3, 4, 9), new Edge(4, 2, 3), new Edge(4, 3, 9) };
AdjMatrixGraphString graph = new AdjMatrixGraphString(vertices,
edges);
System.out.println(带权无向图, + graph.toString());
System.out.println(插入顶点F,插入边(A,F,20),删除顶点C,删除边(D,E));
int i = graph.insertVertex(F);
graph.insertEdge(0, i, 20);
graph.insertEdge(i, 0, 20);
graph.removeVertex(2);
graph.removeEdge(2, 3);
graph.removeEdge(3, 2);
System.out.println(graph.toString());
AdjMatrixGraphString graph1 = new AdjMatrixGraphString(vertices,
edges);
S
您可能关注的文档
最近下载
- 新能源汽车专业实训室建设方案(供货价200万)2021108.doc VIP
- 王浩—水资源全过程动态评价理论方法与实践.ppt VIP
- 部编版小学语文四年级下册第6课《飞向蓝天的恐龙》精品课件.pptx
- 水池满水试验规定(闭水试验).pdf VIP
- 专题1.6 角平分线的判定与性质【十大题型】(举一反三)(北师大版)(原卷版).docx VIP
- 潍柴WD615系列柴油机使用与维修中册.pdf VIP
- 高中全套思维导图.doc VIP
- 医防融合的课件.pptx VIP
- 预检分门诊消毒隔离制度.docx VIP
- Unit 3 Same or Different ? Section A 2a~2e 课件+内嵌音频.pptx VIP
文档评论(0)