/*图的存储及遍历*/
#include<iostream>
using namespace std;
//-----------------------------------
//邻接矩阵的存储及深度和广度遍历
//----------------------------------- /*邻接矩阵的类型定义*/
#define MAX 10000000
#define MAX_VERTEX_NUM 20
typedef enum{ DG,DN,UDG,UDN }GraphKind;//有向图,有向网,无向图,无向网
typedef struct
{
char vexs[MAX_VERTEX_NUM];//用一维数组存储顶点信息
int edges[MAX_VERTEX_NUM][MAX_VERTEX_NUM];//用二维数组充当矩阵,来存储顶点边的信息
int vexnum,edgenum;//顶点树和边数
GraphKind kind;//图的种类
}MGraph; /*构造无向图的邻接矩阵*/
void CreateUDG_AM(MGraph &G,int n,int e)
{
G.vexnum=n;
G.edgenum=e; int i,j,k;
for(i=;i<n;i++)
cin>>G.vexs[i];//输入顶点信息 for(i=;i<n;i++)
for(j=;j<n;j++)
G.edges[i][j]=;//将矩阵初始化为0 for(k=;k<e;k++)
{
cin>>i>>j;//这里只用输入对称的边就行,也就是输入下矩阵或是上矩阵
G.edges[i][j]=G.edges[j][i]=;//输入边的信息
}
} /****************************无向图的深度优先遍历************************/
int visited[MAX_VERTEX_NUM]; void DF_AM(MGraph &G,int i)
{
int j;
cout<<G.vexs[i]<<" ";
visited[i]=;
for(j=;j<G.vexnum;j++)
{
if((G.edges[i][j])==&&(visited[j])==)
DF_AM(G,j);
}
} void DF_Traverse_AM(MGraph &G)
{
int i;
for(i=;i<G.vexnum;i++)
{
visited[i]=;
}
for(i=;i<G.vexnum;i++)
{
if(!visited[i])
DF_AM(G,i);
}
} /*********************无向图的广度优先遍历*****************************/ //循环队列的类型定义
const int Queue_Size=; typedef struct circlQueue
{
int *elem;
int rear;
int front;
int queueSize;
}circlQueue; //初始化
void initQueue_C(circlQueue &Q)
{
Q.elem=new int[Queue_Size];
Q.front=Q.rear=;//首尾指针相等说明队列为空。
Q.queueSize=Queue_Size;
} //入队列
void enterQueue_C(circlQueue &Q,int x)
{
if(((Q.rear+)%Q.queueSize)==Q.front)//判断栈满的情况
cout<<"Queue OverFlow!";
Q.elem[Q.rear]=x;
Q.rear=(Q.rear+)%Queue_Size;//尾指针应以此种方式加1,才会实现循环队列。
} //出队列
char outputQueue_C(circlQueue &Q)
{
int e;
if(Q.rear==Q.front)
cout<<"Queue Empty";
e=Q.elem[Q.front];
Q.front=(Q.front+)%Q.queueSize;;//头指针应以此种方式加1,才会实现循环队列。
return e;
}
//广度遍历
void BF_Traverse_AM(MGraph &G)
{
int i,j,v;
for(i=;i<G.vexnum;i++)
visited[i]=;
circlQueue Q;
initQueue_C(Q);//队列实现了“先被访问的顶点的邻接点”先于“后被访问的顶点的邻接点”被访问
for(i=;i<G.vexnum;i++)
{
if(!visited[i])
{
cout<<G.vexs[i]<<" ";
visited[i]=;
enterQueue_C(Q,i);
while(Q.front!=Q.rear)
{//这个循环是将队列里面的顶点取出来,然后进行下面的for循环
v=outputQueue_C(Q);
for(j=;j<G.vexnum;j++)
{//这个循环是将顶点的全部邻接点依次访问并且入队列
if(G.edges[v][j]&&(!visited[j]))
{
cout<<G.vexs[j]<<" ";
visited[j]=;
enterQueue_C(Q,j);
}
}
}
}
}
} //-----------------------------------------------
//邻接表的存储及深度和广度遍历
//-----------------------------------------------
typedef struct EdgeNode
{//边表结点的定义
int adjvex;//存放邻接点在顶点表中的位置
struct EdgeNode * nextedge;//指向下一个边表结点
int weight;
}EdgeNode; typedef struct VexNode
{//顶点表结点的定义
char vex;//存放顶点信息
EdgeNode * firstedge;//指向第一个边表结点
}VexNode; typedef struct
{//顶点表的定义
VexNode vexs[MAX_VERTEX_NUM];
int vexnum,edgenum;
GraphKind kind;
}LGraph; /*构造有向图的邻接表*/
void CreateDG_AL(LGraph &G,int n,int e)
{
int i,j,k;
G.vexnum=n;
G.edgenum=e;
G.kind=DG;
for(i=;i<n;i++)
{
cin>>G.vexs[i].vex;
G.vexs[i].firstedge=NULL;//初始化为空
}
for(k=;k<e;k++)
{
EdgeNode *p;
cin>>i>>j;
p=new EdgeNode;
p->adjvex=j;
p->nextedge=G.vexs[i].firstedge;
G.vexs[i].firstedge=p;//采用头插法
}
} /*********************有向图的深度优先遍历**************************/
void DF_AL(LGraph &G,int v)
{
int j;
EdgeNode *p;
cout<<G.vexs[v].vex<<" ";
visited[v]=;
for(p=G.vexs[v].firstedge;p;p=p->nextedge)
{
j=p->adjvex;
if(!visited[j])
DF_AL(G,j);
}
} void DF_Traverse_AL(LGraph &G)
{
int i;
for(i=;i<G.vexnum;i++)
{
visited[i]=;
}
for(i=;i<G.vexnum;i++)
{
if(!visited[i])
DF_AL(G,i);
}
} /* 何问起 hovertree.com */
/*********************有向图的广度优先遍历**************************/
void BF_Traverse_AL(LGraph &G)
{
int i,j,v;
EdgeNode *p;
for(i=;i<G.vexnum;i++)
visited[i]=;
circlQueue Q;
initQueue_C(Q);//队列实现了“先被访问的顶点的邻接点”先于“后被访问的顶点的邻接点”被访问
for(i=;i<G.vexnum;i++)
{
if(!visited[i])
{
cout<<G.vexs[i].vex<<" ";
visited[i]=;
enterQueue_C(Q,i);
while(Q.front!=Q.rear)
{//这个循环是将队列里面的顶点取出来,然后进行下面的for循环
v=outputQueue_C(Q);
for(p=G.vexs[v].firstedge;p;p=p->nextedge)
{//这个循环是将顶点的全部邻接点依次访问并且入队列
j=p->adjvex;
if(!visited[j])
{
cout<<G.vexs[j].vex<<" ";
visited[j]=;
enterQueue_C(Q,j);
}
}
}
}
}
}
void main()
{
/*MGraph G;
CreateUDG_AM(G,6,6);
DF_Traverse_AM(G);
cout<<endl;
BF_Traverse_AM(G);*/ LGraph G;
CreateDG_AL(G,,);
DF_Traverse_AL(G);
cout<<endl;
BF_Traverse_AL(G);
}

写这个程序给我的感觉就是乱,思路不是很清晰,遍历的逻辑关系还掌握的不是很熟,只是大概知道是这么回事,但是让自己去写的话,可能就写不出来了!还是要加大对遍历的熟悉程度才行啊!

PS:另外推荐一个让大家真正练手的网站:猪八戒威客网,在这里可以按自己的能力去接一些程序设计的任务。我觉得这是一种很不错的学习方法,当你接了别人的任务,无形中就给了自己压力和动力,然后就会主动的去查询资料,分析问题,可能会历经艰辛才能解决问题,但这中间的过程是很珍贵的,你会通过自己的努力学到很多课本上没有学到的东西,也能过一回需求分析的瘾,真实的体会到和客户进行交流的诸多“纠结”,最后,如果你的努力得到客户的认可,可以获得一笔小小的佣金,当做对自己的奖励,更重要的是,通过做任务,你能体会到自己存在的价值感和对自己能力的肯定!

推荐:http://www.cnblogs.com/roucheng/p/cpphong.html

图的存储及遍历 深度遍历和广度遍历 C++代码实现的更多相关文章

  1. 重新整理数据结构与算法(c#)—— 图的深度遍历和广度遍历[十一]

    参考网址:https://www.cnblogs.com/aoximin/p/13162635.html 前言 简介图: 在数据的逻辑结构D=(KR)中,如果K中结点对于关系R的前趋和后继的个数不加限 ...

  2. 图的存储,搜索,遍历,广度优先算法和深度优先算法,最小生成树-Java实现

    1)用邻接矩阵方式进行图的存储.如果一个图有n个节点,则可以用n*n的二维数组来存储图中的各个节点关系. 对上面图中各个节点分别编号,ABCDEF分别设置为012345.那么AB AC AD 关系可以 ...

  3. C++编程练习(9)----“图的存储结构以及图的遍历“(邻接矩阵、深度优先遍历、广度优先遍历)

    图的存储结构 1)邻接矩阵 用两个数组来表示图,一个一维数组存储图中顶点信息,一个二维数组(邻接矩阵)存储图中边或弧的信息. 2)邻接表 3)十字链表 4)邻接多重表 5)边集数组 本文只用代码实现用 ...

  4. 【数据结构】4.1图的创建及DFS深度遍历(不完善)

    声明:本代码仅供参考,根本就不是正确代码(至少在我看来,有很多BUG和不完美的地方) 图的存储方式选择为邻接表,并且headNode只是来存储一个链表的Node首地址额 总之这个代码写的很垃圾呀很垃圾 ...

  5. 【algo&ds】6.图及其存储结构、遍历

    1.什么是图 图表示"多对多"的关系 包含 一组顶点:通常用 V(Vertex)表示顶点集合 一组边:通常用 E(Edge)表示边的集合 边是顶点对:(v,w)∈ E,其中 v,w ...

  6. 【lhyaaa】图的存储&遍历

    呀,图真是一个令人头疼而又很重要的东西.在现实生活中,我们有很多的问题都不能用树来实现,所以烦人啊不伟大的图就出现了—— 图的存储 没有存储哪来的操作,所以存储是最基础的呢. 邻接矩阵 我们对于图的存 ...

  7. 图的存储与遍历C++实现

    1.图的存储 设点数为n,边数为m 1.1.二维数组 方法:使用一个二维数组 adj 来存边,其中 adj[u][v] 为 1 表示存在 u到 v的边,为 0 表示不存在.如果是带边权的图,可以在 a ...

  8. 数据结构作业——图的存储及遍历(邻接矩阵、邻接表+DFS递归、非递归+BFS)

    邻接矩阵存图 /* * @Author: WZY * @School: HPU * @Date: 2018-11-02 18:35:27 * @Last Modified by: WZY * @Las ...

  9. 多级树的深度遍历与广度遍历(Java实现)

    目录 多级树的深度遍历与广度遍历 节点模型 深度优先遍历 广度优先遍历 多级树的深度遍历与广度遍历 深度优先遍历与广度优先遍历其实是属于图算法的一种,多级树可以看做是一种特殊的图,所以多级数的深/广遍 ...

随机推荐

  1. ejs模板中的四种表达式输出形式

    在ejs模板中,通常会用下面四种方式在HTML中输出服务端的变量或表达式的值: 1. 直接在<%%>中写表达式或变量.这种情况通常只是用来进行表达式计算或给变量赋值,不会有任何输出,被称作 ...

  2. redis系列-redis的使用场景

    redis越来越受大家欢迎,提升下速度,做下缓存,完成KPI之利器呀.翻译一篇文章<<How to take advantage of Redis just adding it to yo ...

  3. Git学习笔记(5)——分支管理

    本文主要记录了分支的原理.分支的创建,删除,合并.以及分支的使用策略. 分支在实际中的作用 假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不 ...

  4. WebKit技术内幕

    WebKit技术内幕(浏览器内核|渲染引擎| HTML5| Chromium项目Committer重磅作品) 朱永盛 著   ISBN 978-7-121-22964-0 2014年6月出版 定价:7 ...

  5. JS 内置对象

    内置对象的定义:有ECMAScript实现提供的.不依赖与宿主环境的对象,在ECMAScript运行之前就已经创建好的对象就叫做内置对象. 就是说,是不需要我们开发人员先是的实例化对象就能够调用和运行 ...

  6. ASP.NET MVC 拦截器IResultFilter

    在ASP.NET MVC中,有一个Result拦截器,实现ResultFilter需要继承一个类(System.Web.Mvc.FilterAttribute)和实现一个类(System.Web.Mv ...

  7. Netty学习四:Channel

    1. Channel Channel是Netty的核心概念之一,它是Netty网络通信的主体,由它负责同对端进行网络通信.注册和数据操作等功能. 1.1 工作原理 如上图所示: 一旦用户端连接成功,将 ...

  8. JS在IE和FireFox之间常用函数的区别小结

    1.event.srcElement 复制代码 代码如下: //srcElement只能在IE下使用target是FireFox使用的,下面是兼容性写法 var obj = e.srcElement ...

  9. Implementation Model Editor of AVEVA in OpenSceneGraph

    Implementation Model Editor of AVEVA in OpenSceneGraph eryar@163.com 摘要Abstract:本文主要对工厂和海工设计软件AVEVA的 ...

  10. ShineTime - 带有 CSS3 闪亮特效的缩略图相册

    ShineTime 是一个效果非常精致的缩略图相册,鼠标悬停到缩略图的时候有很炫的闪光效果,基于 CSS3 实现,另外缩略图也会有立体移动的效果.特别适用于个人摄影作品,公司产品展示等用途,快来来围观 ...