数据结构_图遍历的演示

数据结构_图遍历的演示

ID:47518035

大小:1001.96 KB

页数:12页

时间:2020-01-12

数据结构_图遍历的演示_第1页
数据结构_图遍历的演示_第2页
数据结构_图遍历的演示_第3页
数据结构_图遍历的演示_第4页
数据结构_图遍历的演示_第5页
资源描述:

《数据结构_图遍历的演示》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、实习报告题目:图遍历的演示编译环境:MicrosoftVisualStudio2010功能实现:以邻接表为存储结构,演示在连通无向图上访问全部节点的操作;实现连通无向图的深度优先遍历和广度优先遍历;建立深度优先生成树和广度优先生成树,按凹入表或树形打印生成树。一、需求分析1.以邻接表为存储结构,演示在连通无向图上访问全部节点的操作。该无向图为一个交通网络,共25个节点,30条边,遍历时需要以用户指定的节点为起点,建立深度优先生成树和广度优先生成树,再按凹入表或树形打印生成树。2.程序的测试数据:

2、graph.txt文件所表示的无向交通图。二、概要设计1.主要数据结构设计:structArcNode//边表结点{intvexIndex;//邻接点域,即邻接点在顶点表中的下标ArcNode*next;};structVertexNode//顶点表结点{stringvertex;//数据域ArcNode*firstArc;};structTNode//树结点{stringdata;structTNode*fristchild,*nextchild;};2.邻接表类设计:classGraphTr

3、averse{public:VertexNodeVexList[MaxSize];//顶点表数组intvertexNumberber;//图的顶点数intarcNumberber;//图的边数boolHasCreated;//图是否创建voidReadFile();//从文件读取数据,并建立该图voidDisplayGraph();//以邻接表显示图TNode*DFSForest(int);//建立深度优先生成树voidDFSTree(int,TNode*);//深度优先遍历图TNode*BFS

4、Forest(int);//建立广度优先生成树voidBFSTree(int,TNode*);//广度优先遍历图voidPrintTree(TNode*,int);//按照凹入表方式打印树};一、详细设计1.主要操作函数的实现:(1)建立深度优先生成树函数:TNode*GraphTraverse::DFSForest(intv){inti,j;TNode*p,*q,*DT;j=v;for(i=0;i

5、texNumberber;i++){if(Visited[(i+j)%vertexNumberber]==0){p=newTNode;p->data=VexList[(i+j)%vertexNumberber].vertex;p->fristchild=NULL;p->nextchild=NULL;DT=p;q=p;DFSTree(((i+j)%vertexNumberber),p);}}returnDT;}(2)深度优先遍历图函数:voidGraphTraverse::DFSTree(intv

6、,TNode*DT){intj=0;inti=0;TNode*p,*q;intfirst=1;Visited[v]=1;for(ArcNode*m=VexList[v].firstArc;m;m=m->next){j=m->vexIndex;if(Visited[j]==0){p=newTNode;p->data=VexList[j].vertex;p->fristchild=NULL;p->nextchild=NULL;if(first){DT->fristchild=p;first=0;}e

7、lseq->nextchild=p;q=p;DFSTree(j,q);}}}(1)建立广度优先生成树函数:TNode*GraphTraverse::BFSForest(intv){inti,j;TNode*p,*q,*BT;BT=NULL;j=v;for(i=0;i

8、->data=VexList[(i+j)%vertexNumberber].vertex;p->fristchild=NULL;p->nextchild=NULL;BT=p;q=p;BFSTree(((i+j)%vertexNumberber),p);}}returnBT;}(1)广度优先遍历图函数:voidGraphTraverse::BFSTree(intv,TNode*BT){intfront=-1;intrear=-1;intj=0;inta,b;intfirst=1;a=b=0;TNo

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。