数据结构C语言版-图的建立与遍历

上传人:re****.1 文档编号:560458974 上传时间:2023-05-23 格式:DOCX 页数:4 大小:11.84KB
返回 下载 相关 举报
数据结构C语言版-图的建立与遍历_第1页
第1页 / 共4页
数据结构C语言版-图的建立与遍历_第2页
第2页 / 共4页
数据结构C语言版-图的建立与遍历_第3页
第3页 / 共4页
数据结构C语言版-图的建立与遍历_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《数据结构C语言版-图的建立与遍历》由会员分享,可在线阅读,更多相关《数据结构C语言版-图的建立与遍历(4页珍藏版)》请在金锄头文库上搜索。

1、文档供参考,可复制、编制,期待您的好评与关注! /*-数据结构C语言版图的建立与遍历编程环境 VC+ 6.0Damon2012年4月26号-*/#include#include#include #include#define null 0#define TRUE 1#define FALSE 0#define OVERFLOW -2#define OK 1#define ERROR 0typedef int Status;/图的邻接矩阵数组存储表示-#define INFINITYINT_MAX#define MAX_VERTEX_NUM20typedef int VRType;typedef

2、 char VertexType20;typedef int Boolean;typedef struct ArcCellVRType adj;/InfoType *info;ArcCell,AdjMatrixMAX_VERTEX_NUMMAX_VERTEX_NUM;typedef structVertexType vexsMAX_VERTEX_NUM;AdjMatrix arcs;int vexnum,arcnum;MGraph;/*图的临接表存储表示-typedef struct ArcNodeint adjvex;struct ArcNode *nextarc;InfoType *inf

3、o;ArcNode;typedef struct VNodeVertexType data;ArcNode *firstarc;VNode,AdjListMAX_VERTEX_NUM;typedef structAdjList vertices;int vexnum,arcnum;int kind;ALGraph; */采用数组(邻接矩阵)表示法,构造无向图G-int LocateVex(MGraph *G,VertexType v);int CreateGraph(MGraph *G)int i,j,k;VertexType v1,v2;printf(请依次输入无向网的顶点数和弧数:n);s

4、canf(%d%d,&G-vexnum,&G-arcnum);printf(请输入 %d 顶点向量:,G-vexnum);for(i=0;ivexnum;i+)scanf(%s,G-vexsi);printf(顶点列表:n);for(i=0;ivexnum;i+)puts(G-vexsi);for(i=0;ivexnum;i+)for(j=0;jvexnum;j+)G-arcsij.adj=0;printf(n请输入 %d 条弧关系的邻接矩阵:n,G-arcnum);for(k=0;karcnum;k+)scanf(%s%s,v1,v2);i=LocateVex(G,v1);j=LocateV

5、ex(G,v2);G-arcsij.adj=1;G-arcsji=G-arcsij;return(1);int LocateVex(MGraph *G,VertexType v)int i;for(i=0;ivexnum;i+)if (strcmp(v,G-vexsi)=0) break;return(i);/查找第一个邻接点-int FirstAdjVex(MGraph *G,int v)int j,p=-1;for(j=0;jvexnum;j+)if(G-arcsvj.adj=1)p=j;break;return(p);/查找下一个邻接点-int NextAdjVex(MGraph *G,

6、int v,int w)int j,p=-1;for(j=w+1;jvexnum;j+)if(G-arcsvj.adj=1)p=j; break;return(p);/按邻接矩阵方式输出无向图-void PrintGraph(MGraph *G)int i,j;printf(n无向图为:n);for(i=0;ivexnum;i+)printf(%10s,G-vexsi);for(j=0;jvexnum;j+)printf(%4d,G-arcsij.adj);printf(n);/图的深度遍历-Boolean visitedMAX_VERTEX_NUM;void Dfs(MGraph *G,in

7、t v)int w;visitedv=TRUE;printf(%s,G-vexsv);for(w=FirstAdjVex(G,v); w=0;w=NextAdjVex(G,v,w)if(!visitedw) Dfs(G,w);void DfsTraverse(MGraph *G)int v;for (v=0;vvexnum;v+)visitedv=FALSE;for(v=0;vvexnum;v+)if(!visitedv) Dfs(G,v);/主函数用采用数组(邻接矩阵)表示法,构造无向网G-void main()MGraph G;CreateGraph(&G);PrintGraph(&G);printf(n深度遍历:n); DfsTraverse(&G); printf(n); /

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 行业资料 > 国内外标准规范

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