已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据结构作业4图 参考答案作业4. 图l 非编程作业参考答案:41375625abced1 已知带权无向图如图所示:(1). 根据普里姆(Prim)算法,求它的从顶点a出发的最小生成树(写出过程,即添加顶点、边次序);(2). 根据克鲁斯卡尔(Kruskal)算法,求该图的最小生成树(写出过程,即添加边次序)。普里姆(Prim)算法:克鲁斯卡尔(Kruskal)算法:2aafbdgcheA697832513024212. 已知带权有向图如图所示:(1). 画出该图的邻接矩阵存储结构;(2). 请写出该图的一个拓扑有序序列;(3). 求从顶点a到其余各顶点之间的最短路经及最短路经长度,并给出计算过程。图G的一个拓扑序列:abdfecgh afbdecghabdfegch afbdegch 从a出发到其它顶点的最短路径及其计算过程:l 编程作业:请编写一个完整的程序,建立有向图的邻接表存储结构,并判断两顶点间是否有路径存在,要求:(1) 主函数功能:从键盘读入有向图的顶点数、有向边数,调用函数CreateAdjList()建立邻接表;在主函数中输出每个顶点的数据域及其所有邻接点;从键盘读入两个顶点vs、vt()的数据域,调用函数Path()判断其间是否存在路径;(2) CreateAdjList():建立有向图邻接表。功能:从键盘接收各顶点数据域及各条有向边所依附的顶点(如:“2,3”代表该边依附的两个顶点在表头数组中的下标为2和3),要求单链表中结点按数据域升序排序;(3) Path(): 判断两顶点间是否存在路径,如果存在,将打印该路径(若存在多条路径,打印其中一条即可)。例:输入:请输入顶点和边的数目:8,9 /(在main()函数中输入) 请输入各顶点数据域:a b c d e f g h/(在CreateAdjList()中输入) 请输入各条边:1,2 1,3 2,4 3,6 3,7 4,8 5,2 5,8 6,7 输出:图的邻接表为:a 2 3 /(在main()函数中输出) b 4 c 6 7 d 8 e 2 8 f 7 g h 输入: 请输入要查找是否存在路径的顶点:a,h 输出: 顶点a和d之间存在路径,路经为:a b d h 输入: 请输入要查找是否存在路径的顶点:a,e 输出: 顶点a和e之间不存在路径参考答案:#include#include#define Max_Vertex_Num 10typedef char VertexType;int visitedMax_Vertex_Num;int visitpathMax_Vertex_Num;int pathvexnum;int flag;/单链表结点(弧结点)typedef struct Arcnode int adjvex; /该弧所指向顶点(在表头数组中)的位置 struct Arcnode *nextarc; /指向依附该顶点下一条边或弧 ArcNode;/头结点typedef struct Vnode VertexType data; /顶点信息 Arcnode *firstarc; /指向第一条依附该顶点的弧 VNode, AdjListMax_Vertex_Num;/图的定义typedef struct AdjList vertices; / 表头数组 int vexnum, arcnum; / 图中顶点及弧的数目 ALGraph;/建立邻接表void CreateAdjList (ALGraph &G)int k,i,j;ArcNode *p,*q,*s;for(k=1;k=G.vexnum;k+)printf(input data:);fflush(stdin);scanf(%c,&G.verticesk.data);G.verticesk.firstarc=NULL;for(k=0;kadjvex=j;s-nextarc=NULL;q=NULL;p=G.verticesi.firstarc;while(p!=NULL)&(jp-adjvex)q=p; p=p-nextarc;if(p=NULL&q=NULL)G.verticesi.firstarc=s;else if(p=NULL&q!=NULL)q-nextarc=s;else if(p!=NULL&q=NULL)G.verticesi.firstarc=s;s-nextarc=p;elseq-nextarc=s;s-nextarc=p;/按深度优先判断顶点vx和vy间是否存在路径void DFSPath(ALGraph G, int v, VertexType vy) ArcNode *w; int i;visitpath+pathvexnum=v; visitedv=1; w=G.verticesv.firstarc; /顶点v的第一个邻接点 while(w!=NULL) /是否存在 i=w-adjvex; /邻接点下标if(G.verticesi.data=vy)flag=1;return; else if(flag=0&visitedi=0)DFSPath(G,i,vy); w=w-nextarc; /v的下一个邻接点 if(flag=0) pathvexnum-;/从路径上删除Vvoid Path(ALGraph G, VertexType vx, VertexType vy)int i;for(i=1;i=Max_Vertex_Num;i+)visitedi=0;for(i=1;i=G.vexnum;i+)if(G.verticesi.data=vx)break;DFSPath(G,i,vy);if(flag=1)printf(顶点%c到顶点%c之间存在路径,路经为:,vx,vy);for(i=1;i=pathvexnum;i+)printf(%ct,G.verticesvisitpathi.data);printf(%cn,vy);elseprintf(顶点%c到顶点%c之间不存在路径n,vx,vy);void main()ALGraph G;int i;VertexType vx,vy;ArcNode *p;printf(请输入顶点和边的数目:);scanf(%d,%d,&G.vexnum,&G.arcnum);CreateAdjLi
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 科普助力双减协议书
- 电信查签的协议合同
- 中国传统礼仪文化介绍
- 胃食管反流病常见症状及护理手段
- 2025-2026学年广东省揭阳市高一上学期期中自编模拟地理试卷(人教版)
- 2025-2026学年北京市长水教育集团高一上学期10月质量检测地理试题(解析版)
- 肠道感染症状解读与护理措施分享
- 微笑训练礼仪讲解
- 上肢训练后拉伸
- 脊柱骨折常见症状及护理方法
- AQ-T2050.1-2016 金属非金属矿山安全标准化规范导则
- 铁路专用线设计规范(试行)(TB 10638-2019)
- 施工方案 外墙真石漆(翻新施工)
- 2024年江西省鄱阳湖融资租赁有限公司招聘笔试参考题库含答案解析
- 10000中国普通人名大全
- 水资源调查实训报告
- 《数字经济学》 课件 贾利军 专题1:数字经济的历史溯源、科学内涵与技术基础研究;专题2:数字化革命及其对社会生产过程的影响研究
- 金属加工企业机加工安全风险分级管控清单
- 白杨礼赞 全国优质课一等奖
- 我国农村宗教信仰状况的调研报告
- 江苏教师资格认定体检标准及操作规程
评论
0/150
提交评论