第十二周项目3-图遍历算法的实现
来源:互联网 发布:ubuntu在线安装jdk1.7 编辑:程序博客网 时间:2024/05/22 06:07
/*Copyright (c)2015,烟台大学计算机与控制工程学院All rights reserved.文件名称:第十二周项目3 - 图遍历算法实现.cpp作 者:高露完成日期:2015年11月30日版 本 号:v1.0问题描述: 实现图遍历算法,分别输出如下图结构的深度优先(DFS)遍历序列和广度优先遍历(BFS)序列。 输入描述: 若干测试数据。*/#define MAXV 100 //最大顶点个数#define INF 32767 //INF表示∞typedef int InfoType;//以下定义邻接矩阵类型typedef struct{ int no; //顶点编号 InfoType info; //顶点其他信息,在此存放带权图权值} VertexType; //顶点类型typedef struct //图的定义{ int edges[MAXV][MAXV]; //邻接矩阵 int n,e; //顶点数,弧数 VertexType vexs[MAXV]; //存放顶点信息} MGraph; //图的邻接矩阵类型//以下定义邻接表类型typedef struct ANode //弧的结点结构类型{ int adjvex; //该弧的终点位置 struct ANode *nextarc; //指向下一条弧的指针 InfoType info; //该弧的相关信息,这里用于存放权值} ArcNode;typedef int Vertex;typedef struct Vnode //邻接表头结点的类型{ Vertex data; //顶点信息 int count; //存放顶点入度,只在拓扑排序中用 ArcNode *firstarc; //指向第一条弧} VNode;typedef VNode AdjList[MAXV]; //AdjList是邻接表类型typedef struct{ AdjList adjlist; //邻接表 int n,e; //图中顶点数n和边数e} ALGraph; //图的邻接表类型//功能:由一个反映图中顶点邻接关系的二维数组,构造出用邻接矩阵存储的图//参数:Arr - 数组名,由于形式参数为二维数组时必须给出每行的元素个数,在此将参数Arr声明为一维数组名(指向int的指针)// n - 矩阵的阶数// g - 要构造出来的邻接矩阵数据结构void ArrayToMat(int *Arr, int n, MGraph &g); //用普通数组构造图的邻接矩阵void ArrayToList(int *Arr, int n, ALGraph *&); //用普通数组构造图的邻接表void MatToList(MGraph g,ALGraph *&G);//将邻接矩阵g转换成邻接表Gvoid ListToMat(ALGraph *G,MGraph &g);//将邻接表G转换成邻接矩阵gvoid DispMat(MGraph g);//输出邻接矩阵gvoid DispAdj(ALGraph *G);//输出邻接表G#include <stdio.h>#include <malloc.h>extern visited[MAXV];void DFS(ALGraph *G, int v){ ArcNode *p; int w; visited[v]=1; printf("%d ", v); p=G->adjlist[v].firstarc; while (p!=NULL) { w=p->adjvex; if (visited[w]==0) DFS(G,w); p=p->nextarc; }}int visited[MAXV];int main(){ int i; ALGraph *G; int A[5][5]= { {0,1,0,1,0}, {1,0,1,0,0}, {0,1,0,1,1}, {1,0,1,0,1}, {0,0,1,1,0} }; ArrayToList(A[0], 5, G); for(i=0; i<MAXV; i++) visited[i]=0; printf(" 由2开始深度遍历:"); DFS(G, 2); printf("\n"); for(i=0; i<MAXV; i++) visited[i]=0; printf(" 由0开始深度遍历:"); DFS(G, 0); printf("\n"); return 0;}
<span style="font-family:Arial;BACKGROUND-COLOR: #ffffff">运行结果:</span>
<span style="font-family:Arial;BACKGROUND-COLOR: #ffffff"><img src="http://img.blog.csdn.net/20151130163335876?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" /></span>
<span style="font-family:Arial;BACKGROUND-COLOR: #ffffff">总结:</span>
<span style="font-family:Arial;BACKGROUND-COLOR: #ffffff">主要是bfs和dfs算法的实现问题</span>
0 0
- 第十二周项目3-图遍历算法的实现
- 第十二周 项目3 图遍历算法的实现
- 第十二周项目3-图遍历算法的实现BFS
- 第十二周项目-3图遍历算法的实现
- 第十二周项目3 图的遍历算法实现
- 第十二周实践项目~图遍历算法的实现
- 第十二周项目3—图遍历算法实现
- 第十二周 项目3 图遍历算法实现
- 第十二周实践项目3—图遍历算法实现
- 第十二周 项目3-图遍历算法实现(1)
- 第十二周项目3--图遍历算法实现
- 第十二周项目3-图遍历算法实现
- 第十二周 项目3-图遍历算法实现(2)
- 第十二周项目3图遍历算法实现
- 第十二周项目3-图遍历算法实现
- 第十二周 - 项目3 - 图遍历算法实现
- 第十二周项目3 - 图遍历算法实现(1)
- 第十二周项目3 - 图遍历算法实现(2)
- 【Swing】windowslistener
- 项目1.4—验证算法
- 学习的网站(视频)
- iOS开发拓展篇—应用之间的跳转和数据传
- 图片加载提速--方法一httpcache
- 第十二周项目3-图遍历算法的实现
- Masonry自动布局详解七:ScrollView循环布局
- 项目3 - 是否二叉排序树?
- 14周—平衡二叉树
- 第十四周项目一(2)验证算法
- 使用Navicat连接管理远程linux服务器上的mysql数据库
- 第14周、项目1—验证算法 (2)
- 第十四周项目三~~
- 第十四周项目3-是否二叉排序树