图的邻接表存储实现及深度优先遍历

图的邻接表存储实现及深度优先遍历

ID:11302749

大小:110.50 KB

页数:10页

时间:2018-07-11

图的邻接表存储实现及深度优先遍历_第1页
图的邻接表存储实现及深度优先遍历_第2页
图的邻接表存储实现及深度优先遍历_第3页
图的邻接表存储实现及深度优先遍历_第4页
图的邻接表存储实现及深度优先遍历_第5页
资源描述:

《图的邻接表存储实现及深度优先遍历》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、第四次实验报告图的邻接表存储实现及深度优先遍历学号0708140119电子072姓名陆萍萍一、问题描述1、程序所能达到的基本功能构建以邻接表形式存储的表及实现深度优先遍历并输出结果。2、输入的形式和输入值的范围:根据提示进行输入:先输入要构建的表的结点数和边数,要求是整型;输入各结点的代号,这里用char型,也可在源程序中改变其它形式;输入各边的头结点和尾结点的代号;3、输出的形式若正常输入,则输出深度优先遍历的最后结果。用各结点的代码表示。测试数据要求第一组数据:结点数和边数:44结点名称:abcd边:a-ba-

2、cb-cc-d输出a-b-c-d-over!第二组数据:图如下:输出a-b-c-d-e-f-g-over!3、概要设计1、抽象数据类型,它们的作用//图的结点类templateclassTVex{};//图类templateclassGraph{}//链表存储2主程序流程及模块调用关系(1)主程序模块:voidmain{构造一个图,对T实例化(char)。调用Graph中的Create函数;调用Graph中的DFS函数;}(2)调用关系如下TemplateTlinkl

3、istTemplateTvexTemplateGraph1、核心算法的粗线条伪码3、详细设计(要求主要变量和语句加注释)1、抽象数据类型的实现:包括类型定义和各个操作的实现。1)TVex的详细设计(1)私有数据类型的定义private:Tm_elem;TLinklistm_arcs;2)Graph的详细设计(1)私有数据类型的定义private:TVexVextex[maxnum];intvexnum;intarcnum;intkind;intsymbol[maxnu

4、m];(2)公有函数成员的定义Graph();voidCreate();intLocateVex(Tv);voidDFS();voidDFS_IN(inti);(3)具体实现★templatevoidGraph::Create(){Tv1,v2;inti,j;cout<<"*********************基本信息*****************************"<>vexnum>>arcnum;cout<<"**

5、*********************结点***************************"<>Vextex[l].m_elem;}cout<<"***********************边数***************************"<

6、>>v1>>v2;i=LocateVex(v1);j=LocateVex(v2);Vextex[i].m_arcs.InsertLate(j);Vextex[j].m_arcs.InsertLate(i);}cout<<"************************结果**************************"<intGraph::LocateVex(Tv){for(inti=0;i

7、);if(i==vexnum)return-1;elsereturni;}★templatevoidGraph::DFS(){DFS_IN(0);cout<<"over!"<voidGraph::DFS_IN(inti){intindex;symbol[i]=1;cout<";for(intj=0;;j++){index=Vextex[i].m_arcs.GetElem(j+1);if(inde

8、x!=-1){if(symbol[index]!=1)DFS_IN(index);}elsebreak;}}1、其他主要算法的实现将次要算法均设为Graph的公有函数成员2、主程序的实现Voidmain(){huffmanTreeh;int*ww,n;char*cc;cout<<"请输入叶子节点的个数:";cin>>n;ww=newint[n];

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

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

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