首页 > 其他 > 详细

BFS广度优先遍历

时间:2015-06-03 17:32:18      阅读:191      评论:0      收藏:0      [点我收藏+]

队列实现广度优先遍历

#include <iostream>
#include <queue>
using namespace std;

int  visit[5]={0};

typedef struct {
        char vexs[5];
        int AdjMatrix[5][5];
        int vexnum;
        }Graph;

Graph g={
    {a,b,c,d,e},
      {
       0,1,0,1,0,
       1,0,1,0,1,
       0,0,0,1,1,
       1,0,0,0,0,
       0,1,1,0,0
      } ,
      5
      };

 queue<int> list;;


int BFS(Graph *g,int nowVex){

    if(visit[nowVex]==0)
    cout<<"visit "<<g->vexs[nowVex]<<" ";
    visit[nowVex]=1;

    if(list.size()!=0)
    list.pop();
    for(int i=0;i<g->vexnum;i++)
    {
        if(g->AdjMatrix[nowVex][i]==1&&visit[i]==0)
        {
            list.push(i);
        //    cout<<"nowVex "<<nowVex<<" push "<<g->vexs[i]<<endl;
        }
    }

    while(list.size()!=0){
         //  cout<<" list front is "<<g->vexs[list.front()]<<endl;
           BFS(g,list.front());
    }
    return 0;
}


int main()
{
    BFS(&g,0);
}

 

BFS广度优先遍历

原文:http://www.cnblogs.com/lxdonge/p/4549417.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!