数构课程设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数构课程设计

福建农林大学计算机与信息学院 计算机类 课程设计报告 课程名称: 算法与数据结构 课程设计题目: 网的存储结构及Prim算法 姓 名: 林忠信 系: 数学系 专 业: 数学与应用数学 年 级: 2009 学 号: 091153023 指导教师: 宁正元 职 称: 教授 2011年 1 月 20 日 目 录 1、课程设计的目的?…………………………………………………………1 2、课程设计的要求?…………………………………………………………1 3、课程设计的内容?…………………………………………………………1 3.1需求分析………………………………………………………………1 3.2概要设计?………………………………………………………………1 3.3详细设计?………………………………………………………………3 3.4程序调试与测试结果?……………………………………………………7 3.5结果分析…………………………………………………………………8 4、总结 ?…………………………………………………………………………8 5、参考文献 ?……………………………………………………………………9 6、附录 …………………………………………………………………………9 网的存储结构及Prim算法 1、课程设计的目的 1.掌握网络的邻接表存储结构。 2.掌握优先队列的基本运算实现。 3.掌握网络的邻接表的算法实现。 4.掌握网络的最小生成树Prim算法实现。 2、课程设计的要求 对任意给定的网络(顶点数和边数自定),建立它的邻接矩阵、邻接表并输出,然后利用Prim算法或Kruskal算法生成它的最小生成树,并输出结果。 3、课程设计的内容 3.1需求分析 所谓邻接矩阵存储结构,就是用一维数组存储图或网的顶点信息,用二维数组表示顶点之间的邻接关系。 邻接表试图和网的一种链式存储结构。在邻接表中,对图或网中的每个顶点建立一个单链表,第i个单链表中的结点是与vi相关联的边所连接的结点。每个结点由3个域(adjvex,info,next)组成,其中邻接点域adjvex指示与顶点vi邻接的点在图中的位置,链域next指示下一条边或弧所连接的结点,数据域info存储和边或弧相关信息。每个单链表都附设一个表头结点(由data域和next域组成),链域next指向链表中的第一个结点外, data域存放顶点vi的有关信息。并将这些表头结点组织为一个单链表。 3.2概要设计? Prim算法是从连通网中的某顶点开始,以此作为生成树的初始状态,然后不断地将网中的其他顶点添加到生成树上,直到最后一个顶点添加到添加到生成树上时得到最小生成树。具体方法: (1)从网中任一顶点开始,先把该顶点包含在生成树中,此时生成树只有一个顶点。 (2)找出一个端点在生成树中另一个端点在生成树外的所有边,并把权值最小的边连同它所关联的另一个顶点添加到生成树中;当有两条以上具有相同最小权值的边可供选择时,选择其中任意一条都可以。 (3)反复执行(1),直到所有顶点都包含在生成树中时为止。 主函数流程图如下: Prim函数流程图如下: 3.3详细设计? #include stdio.h #includemalloc.h #define maxvernum 100 #define max 99 typedef char vertextype; /*顶点类型(可根据需要进行修改)*/ typedef struct {vertextype vex[maxvernum];/*定义顶点向量基类型为顶点类型*/ int adjmatrix[maxvernum][maxvernum];/*定义邻接矩阵为为整型,也可定义为权类型*/ int n,e;/*定义顶点数和边或弧数变量单元*/ }magraphtype;/*magraphtype为以邻接矩阵存储的网类型标识符*/ typedef struct node/*定义表结点的结构*/ {int adjvex,info;/*邻接点域、数据域设为整型*/ struct node *next;/*链域,指向下一个结点的指针*/ }nodetype; typedef struct frontnode/*定义表头结点的结构*/ {vertextype data;/*定义表头结点结构*/ struct node *next;/*数据域为顶点类型*/ }frontnodetype; void prim(magraphtype g,int k,int n) /*prim算法的实现*/ {int i,j,min,p; struct {int adjvex,lowcos

文档评论(0)

zijingling + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档