数据结构实验三,prim最小生成树【精选文档】

上传人:a** 文档编号:48845798 上传时间:2022-01-15 格式:DOC 页数:5 大小:30KB
收藏 版权申诉 举报 下载
数据结构实验三,prim最小生成树【精选文档】_第1页
第1页 / 共5页
数据结构实验三,prim最小生成树【精选文档】_第2页
第2页 / 共5页
资源描述:

《数据结构实验三,prim最小生成树【精选文档】》由会员分享,可在线阅读,更多相关《数据结构实验三,prim最小生成树【精选文档】(5页珍藏版)》请在装配图网上搜索。

1、数据结构实验三,prim最小生成树【精选文档】实验三:Prim最小生成树(验证性、4学时)一、 实验目的和要求理解图的遍历理解构造无向联通图的最小生成树的方法(Prim算法实现)能用Prim算法构造最小生成树出来二、 实验内容和原理 实验内容:用Prim算法构造一颗最小生成树(2) 实验原理: 从网中任一顶点开始,先把该顶点包含在生成树中,此时生成树只有一个顶点.找出一个端点在生成树中另一端点在生成树外的所有边,并把权值最小的边连到同它所关联的另一个顶点添加到生成树中;当有两条及以上具有相同最小权值的边可供选择时,任选一条。反复执行,直到所有顶点都包含在生成树时为止.三、 实验环境硬件:(1)

2、学生用微机(2)多媒体教室或远程教学(3)局域网环境软件:(1)Windows XP中文操作系统 (2)Turbo C 3.0四、 算法描述及实验步骤1、 描述从连通网中的某一定点开始,以此作为生成树的初始状态,然后不断地将网中的其他顶点添加到生成树上,知道最后一个顶点添加到生成树上是得到最小生成树。一个无向连通网的生成树可能不是唯一的,当总代价一定是最小的。2、算法流程图struct MGraph 定义图 输入顶点边数各顶点值记录所输各边树权值 不是最小值最小值将最小权值记在min中输出最小边及权值输出最小生成树各边3、代码(注释)#includestdio.h include includ

3、estdlib。h #includestring。h define MAX_NAME 5 define MAX_VERTEX_NUM 20 /权的上限值*/ typedef char VertexMAX_NAME;/顶点名字串/ typedef int AdjMatrixMAX_VERTEX_NUMMAX_VERTEX_NUM;/*邻接距阵/ struct MGraph/定义图/ Vertex vexsMAX_VERTEX_NUM; AdjMatrix arcs; int vexnum,arcnum; ; typedef struct Vertex adjvex; /*当前点/ int low

4、cost; /*代价/ minsideMAX_VERTEX_NUM; int LocateVex(MGraph G,Vertex u)/定位 int i; for(i=0;iG。vexnum;+i)if(strcmp(u,G。vexsi)=0)return i; return 1; void CreateGraph(MGraph &G) int i,j,k,w; Vertex va,vb; printf(请输入无向网G的顶点数和边数(以空格为分隔)n”); scanf(”d d”,&G。vexnum,&G.arcnum); printf(”请输入%d个顶点的值(d个字符):n”,G。vexnu

5、m,MAX_NAME); for(i=0;iG.vexnum;+i) /* 构造顶点集*/ scanf(%s”,G.vexsi); for(i=0;iG。vexnum;+i) /初始化邻接矩阵*/ for(j=0;jG。vexnum;+j) G.arcsij=0x7fffffff; printf(请输入%d条边的顶点1 顶点2 权值(以空格作为间隔): n,G.arcnum); for(k=0;kG。arcnum;+k) scanf(%ss%d*c”,va,vb,w); i=LocateVex(G,va); j=LocateVex(G,vb); G。arcsij=G.arcsji=w; /对称

6、/ int minimum(minside SZ,MGraph G) int i=0,j,k,min; while(!SZi.lowcost)i+; min=SZi.lowcost; /将最小权值记在min中/ k=i; /*把与边关联的生成树外的顶点序号记在k中*/ for(j=i+1;j0&minSZj.lowcost) min=SZj.lowcost; k=j; return k; void MiniSpanTree_PRIM(MGraph G,Vertex u) int i,j,k; minside closedge; k=LocateVex(G,u); for(j=0;jG。vexn

7、um;+j) strcpy(closedgej.adjvex,u); closedgej.lowcost=G.arcskj; closedgek。lowcost=0; /将顶点vk加入生成树中*/ printf(最小代价生成树的各条边为:n); for(i=1;iG。vexnum;+i) k=minimum(closedge,G); printf(%s-s)n”,closedgek。adjvex,G。vexsk); /输出最小边及权值*/ closedgek。lowcost=0; for(j=0;jG。vexnum;+j) if(G.arcskjclosedgej.lowcost) strcp

8、y(closedgej.adjvex,G.vexsk); closedgej。lowcost=G.arcskj; /修改权值域/ int main() MGraph g; CreateGraph(g); MiniSpanTree_PRIM(g,g.vexs0); system(”PAUSE”); return 0; 五、 调试过程(1) 没有定位(2)没有定义最小生成树(3)j的如何取值,循环没有六、 实验结果(1)实验数据1 实验结果1 实验数据2 实验结果2七、 总结(1)理解用prim算法构造无向联通图的最小生成树的方法;(2)对于如何能够求得最小生成树加深了了解;(3)熟悉的prim算法的构造最小生成树的思路和方法;并且能够运用prim算法构造出最小生成树。附录:1 宁正元 王秀丽.算法与数据结构。北京:清华大学出版社.2 宁正元 王秀丽 林大辉。算法与数据结构习题精解和实验指导.北京:清华大学出版社.3数据结构与程序设计(C语言描述)Robert L.Kruse著 清华大学出版社4实用算法的分析与程序设计 吴文虎 王建德 著 电子工业出版社发奋识遍天下字 ,立志读尽人间书。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!