图遍历的演示课程设计报告

上传人:人*** 文档编号:431150587 上传时间:2022-08-10 格式:DOC 页数:13 大小:632KB
返回 下载 相关 举报
图遍历的演示课程设计报告_第1页
第1页 / 共13页
图遍历的演示课程设计报告_第2页
第2页 / 共13页
图遍历的演示课程设计报告_第3页
第3页 / 共13页
图遍历的演示课程设计报告_第4页
第4页 / 共13页
图遍历的演示课程设计报告_第5页
第5页 / 共13页
点击查看更多>>
资源描述

《图遍历的演示课程设计报告》由会员分享,可在线阅读,更多相关《图遍历的演示课程设计报告(13页珍藏版)》请在金锄头文库上搜索。

1、合肥学院计算机科学与技术系课程设计报告20 1120 12 学年第 二 学期课程 数据结构与算法课程设计名称图遍历的演示学生姓名汪青松学号1004031010专业班级网络工程1班指导教师吕刚、陈圣兵2011 年 6 月图遍历的演示一、问题分析和任务定义很多涉及图上操作的算法都是以图的遍历操作为基础的。试写一个程序,演示在连通的无向图上访问全部结点的操作。将每个结点看做一个地名,如合肥。然后任选国内的城市,起点未合肥,忽略城市间的里程。设图的结点20-30个,每个结点用一个编号表示(如果一个图有n个结点,则它们的编号分别为1,2,n)。通过输入图的全部边(存于数据文件中,从文件读写)输入一个图,

2、每个边为一个数对,可以对边的输入顺序作出某种限制。注意,生成树的边是有向边,端点顺序不能颠倒。二、数据结构的选择和概要设计城市与城市之间的关系使没有方向的,无向图采用邻近多重表来实现,主要要表示无向图中的各个结点和边,在多重表中边是采用两个结点来表示的。在邻接表中Edgenode表示邻接表中的结点类型,其中含有访问标记mark,一条边所依附的两个结点的序号ivex和jvex,以及分别指向依附于ivex和jvex的顶点边的链域ilink和jlink。其中,邻接表中的表头结点用Vexnode表示,包含了顶点信息data和指向第一个边结点的firstedge。用AMLGraph表示整个无向图,包含了

3、图的顶点vexnum和边数edgenum。结点坐标信息:struct loc /结点坐标信息int v; /结点序号int x; /x坐标int y; /y坐标;边结点数据结构:struct Edgenode/边结点 int mark;/标志域,指示该边是否被访问过(0:没有1:有) int ivex,jvex;/该边关联的两个顶点的位置 Edgenode *ilink,*jlink;/分别指向关联这两个顶点的下一条边 ; 顶点结点:struct Vexnode/顶点结点 int data; /顶点名称,用数字表示城市 Edgenode *firstedge;/指向第一条关联该结点的边 ; A

4、MLGraph类:AMLGraph- *adjmulist:Vexnode- vexnum:int- edgenum:int- maxnum:int+ AMLGraph(num1:int,num2:int)+ AMLGraph()+ Locate_Vex(v:int):int+ AML_Init():void+ Judge_Edge(v1:int,v2:int):bool+ DFS_Traverse():void+ DFS(v:int):void+ BFS_Traverse():void+ BFS(v:int):void+ Mark_Unvisited():void+ Display():vo

5、id图-1 AMLGraph类UML图三、详细设计和编码程序主体部分主要包括两大部分,一是遍历算法部分;另一部分是对演示图的处理。遍历算法部分主要包括了,邻接多重表构造的无向图的初始化、深度遍历和广度遍历;对演示图的处理包括了,结点坐标信息的初始化和绘图,运用了graphics.h库中的绘图函数。1、深度遍历函数名称: void DFS(int v) 函数功能:实现一张无向图从一个指定结点的深度搜索遍历,并输出结点序号函数参数: int v 开始的结点具体代码: void DFS(int v)/深度优先搜索遍历(递归)Edgenode *p;visitedv=1;/标志v已被访问coutviv

6、ex=i)if(visitedp-jvex=0) /邻近点未被访问过 dline(lv.x,lv.y,lp-jvex.x,lp-jvex.y); DFS(p-jvex); /递归调用p=p-ilink; else if(visitedp-ivex=0) dline(lv.x,lv.y,lp-ivex.x,lp-ivex.y); DFS(p-ivex);/递归调用 p=p-jlink; 2、广度遍历函数名称:void BFS(int v) 函数功能:实现一张无向图从一个指定结点的广度度搜索遍历,并输出结点序号;函数参数: int v开始的结点,返回参数为void具体代码:void BFS(int

7、 v)/广度优先搜索遍历int i,vi;int QueueMAX_VERTEX_NUM,front=0,rear=0; /建立队列数组Edgenode *p;for(i=0;ivexnum;i+)/全部节点标记为未访问visitedi=0;visitedv=1; /开始结点标记为已访问coutv; /输出当前访问结点位置coutivex=vi)if(visitedp-jvex=0)/边节点内元素未被访问则访问节点内元素,并对其标记已访问visitedp-jvex=1;coutjvexjvex.x,lp-jvex.y); /绘制路径rear=(rear+1)%MAX_VERTEX_NUM;/队

8、列的尾指针计数器加一,即后移一位Queuerear=p-jvex;p=p-ilink;/边节点内元素已被访问,指向下一邻接点elseif(visitedp-ivex=0)visitedp-ivex=1;coutivexivex.x,lp-ivex.y); /绘制路径 rear=(rear+1)%MAX_VERTEX_NUM;Queuerear=p-ivex; p=p-jlink;3、图的创建和初始化函数名称:void AML_Init()函数功能:创建一张固定结点和边数的无向图,边与结点的关系是从文件中读取函数参数:形参为空,返回也为void具体代码: void AML_Init() ifst

9、ream icin;icin.open(d:wenjian2.txt); int i,j,k;int edge302;/二维数组来存储边的关系,30条边和ivex,jvex边集的两结点 for(i=0;iedgenum;i+)for(j=0;jedgeij;for(i=0;ivexnum;i+) /初始化顶点 adjmulisti.data=i+1; adjmulisti.firstedge=NULL; for(k=0;kivex=edgek0;e-jvex=edgek1;/读入2个顶点的值e-ilink=adjmuliste-ivex.firstedge;/将头结点的firstedge指针赋

10、给新结点的ilinkadjmuliste-ivex.firstedge=e;/将头结点的指针指向新结点e-jlink=adjmuliste-jvex.firstedge;/将新结点的jlink指针指向其jvex结点所依附的结点adjmuliste-jvex.firstedge=e; init_location(); /初始化所有结点的坐标信息 4、初始化顶点坐标函数名称:void init_location()函数功能:此函数为初始化顶点坐标,主要用来读取存储在文件中的各个顶点坐标信息函数参数:形参为空,返回值为空具体代码: void init_location() /初始化结点的坐标信息ifstream icin;l=new loc20;icin.open(d:wenjian1.txt);for(int i=1;ili.vli.xli.y;四、 上机调试过程 图-2 具体的图关系图 图-3 存储顶点坐标信息文件五、 测试结果及其分析图-4 深度搜索遍历结果图-5深度搜索遍历演示图-6 广度搜索遍历演示图-7 广度度搜索遍历演示六、用户使用说明本程序采用C+语言在Windows 7+VC6.0环境下编写,主要功能是演示图的两种遍历过程

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号