广度优先遍历

广度优先遍历是非经常见和普遍的一种图的遍历方法了,除了BFS还有DFS也就是深度优先遍历方法。我在我下一篇博客里面会写。

遍历过程

相信每一个看这篇博客的人,都能看懂邻接链表存储图。

不懂的人。请先学下图的存储方法。在我的之前博客里。

传送门:图表示方法

然后我们如果有一个图例如以下:

节点1->3->NULL

节点2->NULL

节点3->2->4->NULL

节点4->1->2->NULL

这样我们已经知道这是一个什么图了。

如果我们从节点1開始遍历。

首先把节点1变成灰色,然后增加到队列(queue)中,然后把全部与节点1的点变成灰色同一时候增加到队列中。

输出并弹出队首元素节点1并把节点1的颜色变为黑色。

然后再把队首元素的相邻节点增加到队列中。然后继续输出并弹出队首元素依次类推。到队列空为止。

代码实现

以下是我写的代码实现。比較简单。

我有写一部分凝视。

//
// main.cpp
// BFS
//
// Created by Alps on 15/3/30.
// Copyright (c) 2015年 chen. All rights reserved.
// #include <iostream>
#include <queue> #ifndef Vertex
#define Vertex int
#endif #ifndef NumVertex
#define NumVertex 4
#endif #define WHITE 0
#define GRAY 1
#define BLACK 2 using namespace std; struct node{
int val;
int weight;
node* next;
node(int v, int w): val(v), weight(w), next(NULL){}
}; typedef node* VList; struct TableEntery{
VList header;
Vertex color;
}; typedef TableEntery Table[NumVertex+1]; void InitTableEntry(Vertex start, Table T){ //init the Graph
Vertex OutDegree = 0;
VList temp = NULL; for (int i = 1; i <= NumVertex; i++) {
scanf("%d",&OutDegree); // input the out degree of vertex
T[i].header = NULL;
T[i].color = WHITE;
for (int j = 0; j < OutDegree; j++) {
temp = (VList)malloc(sizeof(struct node));
scanf("%d %d",&temp->val, &temp->weight);
temp->next = T[i].header;
T[i].header = temp;
}
} T[start].color = GRAY; //init the start vertex color to gray
} void BFS(Vertex start, Table T){
queue<Vertex> Q;
Q.push(start);
VList temp = NULL;
while (!Q.empty()) { //if queue is not empty, then the bfs is not over
temp = T[Q.front()].header; //find the front of the queue
while (temp) { //if the front vertex has next vertex
if (T[temp->val].color == WHITE) {
Q.push(temp->val); //push the white vertex to queue
T[temp->val].color = GRAY; //change the color to gray
}
temp = temp->next;
}
printf("%d ",Q.front()); //output the vertex
T[Q.front()].color = BLACK; //then change color
Q.pop();
}
} int main(int argc, const char * argv[]) {
Table T;
InitTableEntry(1, T);
BFS(1, T);
return 0;
}

上面的代码就是BFS了。事实上还有非常多其它实现方法。

都能够。

算法学习 - 图的广度优先遍历(BFS) (C++)的更多相关文章

  1. 图的广度优先遍历算法(BFS)

    在上一篇文章我们用java演示了图的数据结构以及图涉及到的深度优先遍历算法,本篇文章将继续演示图的广度优先遍历算法.广度优先遍历算法主要是采用了分层的思想进行数据搜索.其中也需要使用另外一种数据结构队 ...

  2. 数据结构与算法之PHP用邻接表、邻接矩阵实现图的广度优先遍历(BFS)

    一.基本思想 1)从图中的某个顶点V出发访问并记录: 2)依次访问V的所有邻接顶点: 3)分别从这些邻接点出发,依次访问它们的未被访问过的邻接点,直到图中所有已被访问过的顶点的邻接点都被访问到. 4) ...

  3. 图的广度优先遍历(bfs)

    广度优先遍历: 1.将起点s 放入队列Q(访问) 2.只要Q不为空,就循环执行下列处理 (1)从Q取出顶点u 进行访问(访问结束) (2)将与u 相邻的未访问顶点v 放入Q, 同时将d[v]更新为d[ ...

  4. 广度优先遍历-BFS、深度优先遍历-DFS

    广度优先遍历-BFS 广度优先遍历类似与二叉树的层序遍历算法,它的基本思想是:首先访问起始顶点v,接着由v出发,依次访问v的各个未访问的顶点w1 w2 w3....wn,然后再依次访问w1 w2 w3 ...

  5. PTA 邻接表存储图的广度优先遍历(20 分)

    6-2 邻接表存储图的广度优先遍历(20 分) 试实现邻接表存储图的广度优先遍历. 函数接口定义: void BFS ( LGraph Graph, Vertex S, void (*Visit)(V ...

  6. PTA 邻接表存储图的广度优先遍历

    试实现邻接表存储图的广度优先遍历. 函数接口定义: void BFS ( LGraph Graph, Vertex S, void (*Visit)(Vertex) ) 其中LGraph是邻接表存储的 ...

  7. Python数据结构与算法之图的广度优先与深度优先搜索算法示例

    本文实例讲述了Python数据结构与算法之图的广度优先与深度优先搜索算法.分享给大家供大家参考,具体如下: 根据维基百科的伪代码实现: 广度优先BFS: 使用队列,集合 标记初始结点已被发现,放入队列 ...

  8. 图的深度优先遍历(DFS)和广度优先遍历(BFS)

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  9. 图的深度优先遍历(DFS)和广度优先遍历(BFS)算法分析

    1. 深度优先遍历 深度优先遍历(Depth First Search)的主要思想是: 1.首先以一个未被访问过的顶点作为起始顶点,沿当前顶点的边走到未访问过的顶点: 2.当没有未访问过的顶点时,则回 ...

随机推荐

  1. UVA 725 – Division

    Description   Write a program that finds and displays all pairs of 5-digit numbers that between them ...

  2. Codeforces 396B On Sum of Fractions 数论

    题目链接:Codeforces 396B On Sum of Fractions 题解来自:http://blog.csdn.net/keshuai19940722/article/details/2 ...

  3. Android使用ksoap2-android调用WebService学习

    之前主要做客户端UI交互,很少处理数据和接触服务端,但现在的移动设备根本不可能离得开网络连接,数据的交换.最近学习的是在android端如何去调用远程WebService,都说WebService是一 ...

  4. jquery ajax验证用户名是否存在(后台spring mvc)

    controller层 @ResponseBody @RequestMapping(value = "/user/isExist", produces = "applic ...

  5. 测试关闭mojo utf-8

    [root@wx03 ~]# cat test.pl use Mojolicious::Lite; use JSON qw/encode_json decode_json/; use Encode; ...

  6. 怎么提高ArcGIS for Desktop10.x的性能

    Esri新公布了一篇提高ArcGIS for Desktop10.x的性能的文章.大家能够关注一下 http://support.esri.com/en/knowledgebase/techartic ...

  7. 不是技术牛人,如何拿到国内IT巨头的Offer(转)

    不久前,byvoid面阿里星计划的面试结果截图泄漏,引起无数IT屌丝的羡慕敬仰.看看这些牛人,NOI金牌,开源社区名人,三年级开始写Basic…在跪拜之余我们不禁要想,和这些牛人比,作为绝大部分技术屌 ...

  8. Org-mode五分钟教程ZZZ - Kaka Abel的日志 - 网易博客

    Org-mode五分钟教程ZZZ - Kaka Abel的日志 - 网易博客 Org-mode五分钟教程ZZZ  

  9. SAE php 研究(2)

    1.在SAE新建项目打印出phpinfo <?php  print phpinfo(); ?> 2. 可见:PHP Version 5.3.8 [使用的是php5.3.8编译的] 3. 可 ...

  10. [Android]Volley源代码分析(店)应用

    通过前面的谈话,我相信你有Volley有了一定的了解了原理.本章将给出一些我们的应用程序都可以在样品中直接使用,第一样品是 NetworkImageView类,事实上NetworkImageView顾 ...