欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > DOC文档下载  

    无向图深度遍历邻接矩阵报告材料.doc

    • 资源ID:10547       资源大小:75KB        全文页数:9页
    • 资源格式: DOC        下载积分:10金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    无向图深度遍历邻接矩阵报告材料.doc

    word无向图的深度遍历实验报告系别计算机系班级学号某某课程名称数据结构实验日期实验名称图的遍历成绩实验目的:1.掌握图的结构特征,以与邻接矩阵和邻接表存储结构的特点和实现。2.掌握在邻接矩阵或邻接表存储结构如下图的深度优先和广度优先遍历算法思想与其程序实现。实验条件:实验内容:1. 问题描述以邻接矩阵或邻接表为存储结构,利用深度优先搜索算法或广度优先搜索算法遍历一个无向图。给出遍历序列,假如该图不连通,给出其连通分量的个数和各连通分量的遍历序列。2. 数据结构类型定义采用邻接矩阵为存储结构:typedef struct Arode int adj;Arode;/邻接矩阵元素的定义typedef struct VertexData vertexMAX_VERTEX_NUM;/为顶点的集合 Arode arcsMAX_VERTEX_NUMMAX_VERTEX_NUM; int vexnum,arum;/vexnum为顶点数,arum为弧数AdjMatrix; /邻接矩阵的定义3. 模块划分(1) 创建一个无向图以邻接矩阵为存储结构:void CreateUDN(AdjMatrix *G)(2) 邻接矩阵的定位:int LocateVertex(AdjMatrix *G,VertexData v)(3)深度优先遍历:void DepthFirstSearch(AdjMatrix G,int v)(4) 无向图的遍历:void TraverseGraph(AdjMatrix G)(5) 主函数: void main()4. 详细设计5. #include <stdio.h>6. #include <stdlib.h>7. #include<math.h>8. #define OK 19. #define ERROR 010. #define FALSE 011. #define TRUE 112. #define MAX_VERTEX_NUM 10013. int visitedMAX_VERTEX_NUM;14. typedef int AdjType;15. typedef int VertexData;16. typedef enumDG,DN,UDG,UDNGraphKind;17. typedef struct Arode18. AdjType adj;19. Arode;20. typedef struct21. VertexData vertexMAX_VERTEX_NUM;22. Arode arcsMAX_VERTEX_NUMMAX_VERTEX_NUM;23. int vexnum,arum;24. AdjMatrix;25. int LocateVertex(AdjMatrix *G,VertexData v)26. int j=ERROR,k;27. for(k=0;k<G->vexnum;k+)28. if(G->vertexk=v)29. j=k;break;30. return (j);31. 32.33. int GreateUDN(AdjMatrix *G)34. int i,j,k;35. VertexData v1,v2;36. printf("输入图的顶点数和弧数:n");37. scanf("%d,%d",&G->vexnum,&G->arum);38. getchar();39. for(i=0;i<G->vexnum;i+)40. 41. for(j=0;j<G->vexnum;j+)42. G->arcsij.adj=FALSE;43. 44. printf("输入图的顶点:n");45. for(i=0;i<G->vexnum;i+)46. scanf("%d",&G->vertexi);47. 48. for(k=0;k<G->arum;k+)49. 50. printf("输入一条弧的两个顶点:");51. scanf("%d,%d",&v1,&v2);52. getchar();53. i=LocateVertex(G,v1);54. j=LocateVertex(G,v2);55. G->arcsij.adj=1;56. G->arcsji.adj=1;57. 58. return(OK);59. 60.61.62. void DepthFirstSearch(AdjMatrix G,int v)63. int j;64. printf("%d",G.vertexv);65. printf("n");66. visitedv=TRUE;67. for(j=0;j<G.vexnum;j+)68. if(!visitedj&&G.arcsvj.adj=1)69. DepthFirstSearch(G,j);70. 71. void TraverseGraph(AdjMatrix G)72. int i;73. for(i=0;i<G.vexnum;i+) visitedi=FALSE;74. for(i=0;i<G.vexnum;i+)75. if(!visitedi) DepthFirstSearch(G,i);76. 77.78. int main()79. int i,j;80. AdjMatrix G;81. GreateUDN(&G);82. printf("此无向图的深度遍历为:");83. TraverseGraph(G);84. printf("输出邻接矩阵n");85. for(i=0;i<G.vexnum;i+)86. 87. for(j=0;j<G.vexnum;j+)88. 89. printf("%d ",G.arcsij.adj);90. 91. printf("n");92. return 0;93. 94.95. 测试数据与结果第一组测试:输入数据:顶点:1,2预测结果:输出结点数据:1,2输出邻接矩阵 0 1 1 0实际结果:第二组测试: 输入数据:顶点:0,1,2,3,4 预测结果:输出结点数据:0,1,2,3,4输出邻接矩阵 0 1 1 1 0 1 0 0 1 0 1 0 0 1 1 1 1 1 0 1 0 0 1 1 0实际结果:第三组测试:输入数据:顶点:0,1,2,3,4 5 6预测结果:输出结点数据:0123456输出邻接矩阵 0 1 1 1 1 0 0 1 0 1 0 0 0 0 1 1 0 0 00 0 1 1 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0实际结果:实验总结:开始出现各种问题,可能因为我不够理解图的遍历与创建,经过反复修改,让我对图的遍历与创建有了更深的认识。9 / 9

    注意事项

    本文(无向图深度遍历邻接矩阵报告材料.doc)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开