码迷,mamicode.com
首页 > 编程语言 > 详细

【数据结构-图】图的建立以及广度优先遍历算法

时间:2015-04-16 21:59:52      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:数据结构      

本文利用邻接表的方法将图进行了表示,并且利用广度优先遍历方法对图进行遍历

下面是一个图的示例:

技术分享

代码如下:

#include<iostream>
using namespace std;
typedef int VexType;
typedef struct Arcnode{
VexType data;
struct Arcnode *nextarc;
}ArcNode;
typedef struct Vexnode
{


VexType data;
    ArcNode *firstarc;
}Vnode,AdjList[100];
typedef struct Graph
{
AdjList adjlist;
int vexnum;
int arcnum;
}*MGraph,Graph;
MGraph Create_Graph()
{
MGraph mygraph =new Graph;
int key;
int i;
int m;
int x,y,z;
printf("图一共有多少个顶点?\n");
scanf("%d",&x);
mygraph->vexnum=x;
printf("图一共有多少个边?\n");
scanf("%d",&y);
mygraph->arcnum=y;
printf("请输入每个顶点\n");
for(i=1;i<=mygraph->vexnum;i++)
{
scanf("%d",&z);
   mygraph->adjlist[i].data=z;
}
for(i=1;i<=mygraph->vexnum;i++)
{
printf("%d有没有相关连的顶点?有输入1,没有输入0\n",mygraph->adjlist[i].data);
scanf("%d",&key);
if(key)
{
   printf("请输入与%d相关联的顶点,以-123结束\n",mygraph->adjlist[i].data);
            scanf("%d",&m);
ArcNode *p=new ArcNode;
p->data=m;
p->nextarc=NULL;
mygraph->adjlist[i].firstarc=p;
printf("请输入与%d相关联的顶点,以-123结束\n",mygraph->adjlist[i].data);
            scanf("%d",&m);
while(m!=-123)
{
               ArcNode *q=new ArcNode;
  q->data=m;
  p->nextarc=q;
  p=q;
  printf("请输入与%d相关联的顶点,以-123结束\n",mygraph->adjlist[i].data);
               scanf("%d",&m);
}
p->nextarc=NULL;
}
if(!key)
{
mygraph->adjlist[i].firstarc=NULL;
}
//printf("完成了第%d个节点\n",i);
}
printf("done\n");
return mygraph;
}

void prints(MGraph root)
{
MGraph mygraph=root;
int i;
ArcNode *q;
printf("这个图的邻接表表示为:\n");
for(i=1;i<=mygraph->vexnum;i++)
{
printf("%d:",mygraph->adjlist[i].data);
q=mygraph->adjlist[i].firstarc;
if(q)
{
while(q->nextarc!=NULL)
{
printf("%d,",q->data);
q=q->nextarc;
}
printf("%d",q->data);
}
printf("\n");
}
}
void BFS(MGraph root)//广度优先遍历
{
MGraph mygraph=root;
bool *sign=new bool;//标记这个节点是不是被访问了
int i;
for(i=1;i<=mygraph->vexnum;i++)
sign[i]=false;
Vnode *Q[100];
Vnode *p;
ArcNode *q;
int rear=-1;
int front=-1;
printf("广度优先遍历为:");
for(i=1;i<=mygraph->vexnum;i++)
{
if(!sign[i])
{
printf("%d ",mygraph->adjlist[i].data);
sign[i]=1;
}
Q[++rear]=&(mygraph->adjlist[i]);
while(front!=rear)
{
p=Q[++front];
if(p->firstarc!=NULL)
{
q=p->firstarc;
while(q->nextarc!=NULL)
{
   if(!sign[q->data])
      {
      printf("%d ",q->data);
      Q[++rear]=&(mygraph->adjlist[q->data]);
      sign[q->data]=true;
      q=q->nextarc;
       }
   else
      {
      q=q->nextarc;
      }
     }
if(!sign[q->data])
      {
      printf("%d ",q->data);
      Q[++rear]=&(mygraph->adjlist[q->data]);
      sign[q->data]=true;
       }//访问每个链表中的最后一个元素
}
}
}
}
int main(void)
{
MGraph mygraph;
mygraph=Create_Graph();
BFS(mygraph);
return 0;
}

结果展示:


技术分享


技术分享


【数据结构-图】图的建立以及广度优先遍历算法

标签:数据结构      

原文地址:http://blog.csdn.net/wodeai1625/article/details/45080153

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!