- 1、本文档共18页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[航空航天]数据机构实验报告重要的
淮北师范大学
程序设计课程设计
通讯录管理系统
学 院 计算机科学与技术
专 业 计算机科学与技术(师范)
学 号 20091201019
学 生 姓 名 葛晨晨
指导教师姓名 陈美荣
2011年月日
设计目的typedef struct Road
{
int marked; /*修建公路标志*/
int vertex1; /*城镇a*/
int vertex2; /*城镇b*/
int weight; /*城镇a,b间距离*/
};
2.使用链表实现的存储,链表中结点结构定义如下:
typedef struct node /*每个结点的数据结构*/
{
struct Road data; /*数据域,放学生基本信息*/
struct node *next; /*指针域*/
}Node,*Edge;
程序应具有以下基本功能:
(1) 输入。 | VertexType}
E={,|,∈V∧P(,)?}
其中,G表示一个图,V是图G中顶点的集合,E是V中顶点偶对的有限集,这些顶点偶对称为边,VertexType是用于描述顶点类型,集合E中P(,)的含义是:对有向图来说用“”表示,对无向图来说用“()”表示,即从到 两个顶点之间存在边。
定义二:邻接矩阵
是表示顶点之间相邻关系的矩阵。设G=(V,E)是一个图,其中V={v1,v2,…,vn}。G的邻接矩阵是一个具有下列性质的n阶方阵:(1) 无向图的邻接矩阵是对称的;有向图的邻接矩阵可能是不对称的。(1)定义三:邻接表
是图的一种链式存储结构。在邻接表中,对图中每个顶点建立一个单链表,在第i个单链表中的结点表示依附于顶点vi的边每个结点由3个域组成,其中邻接点域指示与顶点vi邻接的点在途中的位置,链域指示下一条边或弧的结点;数据域存储和边和弧相关的信息。
克鲁斯卡尔算法
设G=(V,E)是网络,最小生成树的初始状态为只有n个顶点而无边的非连通图T=(V,φ),T中每个顶点自成为一个连通分量。
将集合E中的边按权递增顺序排列,从小到大依次选择顶点分别在两个不同连通分量中的边加入图T,则原来的两个连通分量由于该边的连接而成为一个连通分量。
依次类推,直到T中所有顶点都在同一个连通分量上为止,该连通分量就是G的一棵最小生成树.
①初始时,T为只有6个顶点的非连通图。
②边(v1, v2)的两个顶点v1,v2分别属于两个连通分量,将边(v1, v2)加入T。
③同理,将边(v1, v3)加入T。
④由于边(v2, v3)的两个顶点v2,v3属于同一个连通分量,因此,舍去这条边。
⑤同理将边(v0, v1)、(v1, v5)加入T,边(v3, v5)舍去,边(v3, v4)加入T。
这时T中含的边数为5条,成为一个连通分量,T就是G的一棵最小生成树。
主要功能模块流程图
Krushal算法描述:
void kruskal(ALGraph G){
int i,j,min=MAX,k=0, cost=0;//min用于记录最小权值
int set[MAX_VERTEX_NUM]; //判断两个点是否在同一集合里
Node *p,*q,*s;
printf(\n公路最优方案方案为:\n);
printf(起点 终点 路程\n);
for(i = 0; i G.vexnum; ++i) set[i] = i; //初始化,将每个点自身作为一个集合
while(kG.vexnum-1){
for(i=0;iG.vexnum;++i){
if(G.vertices[i].firstarc!= NULL){ //若第i+1个点没有领边,则下一循环
for(p=G.vertices[i].firstarc;p!=NULL;p = p-next) //查找最小权值的边
if(p-data.weightmin){
min=p-data.weight;
q=p;
j=i;
}
}
}
if(G.vertices[j].firstarc==q)
G.vertices[j].firstarc=q-next; //if-else用于删除最小权值的边
else{
for(p=G.vertices[j].firstarc;p!=q;p=p-next)
s=p;
s
您可能关注的文档
- [经济学]纳税任务二三.doc
- [经济学]经济学基础名词解释.doc
- [经济学]经济学多选题.doc
- [经济学]经济法 教案05.pdf
- [经济学]经济法复习资料.doc
- [经济学]经济法简答题.doc
- [经济学]统计资料.doc
- [经济学]经济管理系电子商务091班优秀班级自荐材料.doc
- [经济学]股票投资价值分析2.ppt
- [经济学]自考-高级财务会计-打印版第一章外币会计.doc
- 第二单元 圆柱和圆锥(提升卷)-2023-2024学年六年级数学下册《知识解读+题型专练》(A4版)(苏教版)2.docx
- 第二单元 圆柱和圆锥(单元测试)-【上好课】六年级数学下册同步高效课堂系列(答案)(苏教版).docx
- 美容师初级模拟习题及参考答案解析.docx
- 2024年8月三级广告设计师习题.docx
- 电子商务师三级模拟题+参考答案.docx
- 4月应急响应测试题及答案.docx
- 室内装饰设计师(三级)模拟题.docx
- 2024年6月现代教育技术复习题+参考答案.docx
- 2月农网配电营业工-初级工练习题(附参考答案).docx
- 备战2025年高考数学模拟卷02(新高考八省专用)(解析版).pdf
最近下载
- 中国国家标准 GB/T 6730.61-2022铁矿石 碳和硫含量的测定 高频燃烧红外吸收法.pdf
- 20世纪英国文学(课堂PPT).ppt
- 事业单位法律公共基础知识基础法律.pptx
- 2023年华北水利水电大学计算机应用技术专业《计算机组成原理》科目期末试卷B(有答案).docx VIP
- 第19章wxpython图形用户界面编程.pdf
- (2025春)苏教版一年级数学下册《 两位数加、减整十数》PPT课件.pptx VIP
- 交通警察道路执勤执法安全防护知识分享PPT共52页.ppt VIP
- 儿童学生理财消费观知识主题班会PPT课件:小小理财家.pptx
- 6.3吨随车吊.doc VIP
- 五年级小学生家访记录表.doc VIP
文档评论(0)