- 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算法 姓 名: 林忠信 系: 数学系 专 业: 数学与应用数学 年 级: 2009 学 号: 091153023 指导教师: 宁正元 职 称: 教授
2011年 1 月 20 日
目 录
1、课程设计的目的?…………………………………………………………1
2、课程设计的要求?…………………………………………………………13、课程设计的内容?…………………………………………………………1
3.1需求分析………………………………………………………………1
3.2概要设计?………………………………………………………………1
3.3详细设计?………………………………………………………………3
3.4程序调试与测试结果?……………………………………………………73.5结果分析…………………………………………………………………8
4、总结 ?…………………………………………………………………………85、参考文献 ?……………………………………………………………………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
您可能关注的文档
最近下载
- 新人教版高中数学必修第二册统计全套课件.pptx VIP
- 台球厅消防安全应急预案.docx VIP
- 海外代理协议合同协议.docx VIP
- 初中教科研课题:《初中语文预习方法研究》课题研究工作报告.doc VIP
- 2025至2030年中国新疆维吾尔自治区建筑市场运行态势及行业发展前景预测报告.docx
- 简述10KV 高压配电柜安装.doc VIP
- GB50148-2010 电气装置安装工程电力变压器油浸电抗器、互感器施工及验收规范.pdf VIP
- 2025航天恒星科技有限公司招聘80+人笔试历年参考题库附带答案详解.pdf
- RB∕T 174-2021 司法鉴定法庭科学机构能力专业要求.pdf
- CP-717安装指南.doc VIP
文档评论(0)