第十二周项目3--图遍历算法实现--实现广度优先遍历——BFS

来源:互联网 发布:日式rpg 知乎 编辑:程序博客网 时间:2024/05/23 02:13

问题及代码:

/*    *烟台大学计算机与控制工程学院     *作    者:刘倩*完成日期:2016年11月14日 *问题描述:利用图的算法库实现广度优先遍历序列       */ 
#include <stdio.h>  #include <malloc.h>  #include "graph.h"    void BFS(ALGraph *G, int v)  {      ArcNode *p;      int w,i;      int queue[MAXV],front=0,rear=0; //定义循环队列      int visited[MAXV];     //定义存放节点的访问标志的数组      for (i=0; i<G->n; i++) visited[i]=0; //访问标志数组初始化      printf("%2d",v);            //输出被访问顶点的编号      visited[v]=1;                       //置已访问标记      rear=(rear+1)%MAXV;      queue[rear]=v;              //v进队      while (front!=rear)         //若队列不空时循环      {          front=(front+1)%MAXV;          w=queue[front];             //出队并赋给w          p=G->adjlist[w].firstarc;   //找w的第一个的邻接点          while (p!=NULL)          {              if (visited[p->adjvex]==0)              {                  printf("%2d",p->adjvex); //访问之                  visited[p->adjvex]=1;                  rear=(rear+1)%MAXV; //该顶点进队                  queue[rear]=p->adjvex;              }              p=p->nextarc;       //找下一个邻接顶点          }      }      printf("\n");  }      int main()  {      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);        printf(" 由2开始广度遍历:");      BFS(G, 2);        printf(" 由0开始广度遍历:");      BFS(G, 0);      return 0;  }  

运行结果:


知识点总结:

图的广度遍历。

学习心得

好好画图。



0 0