已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验4 无向图的深度优先搜索一、实验目的 1. 了解图的定义、特点,区分无向图和有向图的概念;2. 了解图的数据结构和搜索方法;3. 掌握无向图的邻接矩阵、邻接表的表示方法;4. 写出无向图的深度优先搜索程序。二、实验要求1. 了解图的定义、特点,区分无向图和有向图的概念;2. 了解图的数据结构和搜索方法;3. 掌握无向图的邻接矩阵、邻接表的表示方法;4. 写出无向图的深度优先搜索程序。三、实验内容设无向图G有n个点e条边,写一算法建立G的邻接多表,并按照深度优先搜索输出顶点,要求该算法时间复杂性为O(n+e),且除邻接多表本身所占空间之外只用O(1)辅助空间。四、实验结果1. 源代码如下:#include#include#include#include#include#define MAX_VERTEX_NUM 30#define MAX_NAME 20typedef char VertexTypeMAX_NAME;/定义边节点typedef struct EBoxbool mark;int ivex,jvex;struct EBox *ilink,*jlink;EBox;/定义顶点节点typedef struct VexBoxVertexType data;EBox *firstedge;VexBox;/定义表示图结构的结构体typedef structVexBox adjmulistMAX_VERTEX_NUM;int vexnum,edgenum;AMLGraph;/根据数据域内容返回数组下标int LocateVexBox(VertexType c,AMLGraph *g)int i;for(i=0;i(*g).vexnum;i+)if(strcmp(c,(*g).adjmulisti.data)=0)return i;return -1;/创建图的函数void CreateGraph(AMLGraph *g)int i,vi,vj;VertexType va,vb;EBox *p;printf(请输入图的顶点数:n);scanf(%d,&(*g).vexnum);printf(请输入图的边数:n);scanf(%d,&(*g).edgenum);printf(请输入图的%d个顶点:n,(*g).vexnum);for(i=0;i(*g).vexnum;i+)scanf(%s,&(*g).adjmulisti.data);(*g).adjmulisti.firstedge=NULL;printf(请输入图的%d条边,顶点之间用空格隔开:n,(*g).edgenum);for(i=0;imark=false; /将边标记为未访问vi=LocateVexBox(va,g);vj=LocateVexBox(vb,g);p-ivex=vi;p-jvex=vj;p-ilink=(*g).adjmulistvi.firstedge;(*g).adjmulistvi.firstedge=p;p-jlink=(*g).adjmulistvj.firstedge;(*g).adjmulistvj.firstedge=p;int FirstAdjvex(int i,AMLGraph *g) /获取顶点的第一条边if(iivex=i)return (*g).adjmulisti.firstedge-jvex;else return (*g).adjmulisti.firstedge-ivex;else return -1;int NextAdjvex(int i,int j,AMLGraph *g) /获取顶点i的相对于j的邻接顶点EBox *p;if(i0|jivex=i&p-jvex!=j)p=p-ilink;else if(p-jvex=i&p-ivex!=j)p=p-jlink;else break;if(p&p-ivex=i&p-jvex=j)p=p-ilink;if(p&p-ivex=i)return p-jvex;else if(p&p-jvex=i)return p-ivex;if(p&p-ivex=j&p-jvex=i)p=p-jlink;if(p&p-ivex=i)return p-jvex;else if(p&p-jvex=i)return p-ivex;return -1;int visitedMAX_VERTEX_NUM;/从下标为v的顶点出发递归的深度优先遍历图void DFS(AMLGraph *g,int v)int w;visitedv=true;printf(%s ,(*g).adjmulistv.data);for(w=FirstAdjvex(v,g);w=0;w=NextAdjvex(v,w,g)if(!visitedw)DFS(g,w);/对图作深度优先遍历void DFSTraverse(AMLGraph *g)int v;for(v=0;v(*g).vexnum;v+)visitedv=false;printf(深度遍历图的结果为:n);for(v=0;v(*g).vexnum;v+)if(!visitedv)DFS(g,v);printf(n);/该函数实现图的所有边的输出void AllEdgenum(AMLGraph *g)int v,i,j;EBox *p;for(v=0;v(*g).vexnum;v+)visitedv=false;printf(该图所有的边为:n);for(v=0;v(*g).vexnum;v+)p=(*g).adjmulistv.firstedge;while(p)if(!(*p).mark)i=(*p).ivex;j=(*p).jvex;printf(%s-%s ,(*g).adjmulisti.data,(*g).adjmulistj.data);(*p).mark=true;p=(*p).ivex=v?(*p).ilink:(*p).jlink;printf(n);void main()AMLGraph g;CreateGraph(&g);DFSTraverse(&g);AllEdgenum(&g);/测试数据/*a b c d ea bb ea dd cc eb c*/2. 运行界面截图如下:五、总结(出现的问题及解决方案或知识点总结)(不少于100字)(1)创建无向图图时,先获取顶点数与边数,再获取所有顶点的data的内容,并将其存入数组中,接下来就是创建边之间的联系了。利用循环读取边,创建边结点并给data赋值,再使该边结点的ilink和jlink分别指向其对应的顶点结点的first
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 天津外国语大学滨海外事学院《三维动画设计》2024-2025学年第二学期期末试卷
- 景德镇陶瓷职业技术学院《物流配送》2024-2025学年第二学期期末试卷
- 青岛职业技术学院《视觉系统设计》2024-2025学年第二学期期末试卷
- 苏州城市学院《道路软件应用》2024-2025学年第二学期期末试卷
- 危化企业消防安全排查
- 企业复印打印传真管理制度
- 煤矿智能化管理制度
- 眉山职业技术学院《动画合成与剪辑》2024-2025学年第二学期期末试卷
- 江西交通职业技术学院《羽毛球III》2024-2025学年第二学期期末试卷
- 榆林职业技术学院《设计透视》2024-2025学年第二学期期末试卷
- 2025-2026学年苏科版(新教材)小学信息科技六年级下册教学计划及进度表
- 2026年包头钢铁职业技术学院单招职业技能测试题库完整答案详解
- 2026年内蒙古乌海市单招职业适应性考试题库及答案详解(有一套)
- XX中学2026年春季学期庆祝“三八”国际妇女节女教职工座谈会讲话
- 2026年内蒙古建筑职业技术学院单招职业技能测试题库附答案解析
- (2026春新版本) 苏教版科学三年级下册全册教学设计
- 2025下半年湖南中学教师资格笔试《综合素质》真题及答案解析
- 服装设计基础课程教学计划
- 中国移动社会招聘在线笔试题
- GB/T 16271-2025钢丝绳吊索插编索扣
- 清华大学考生自述
评论
0/150
提交评论