广度优先遍历

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

遍历过程

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

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

传送门:图表示方法

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

节点1->3->NULL

节点2->NULL

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

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

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

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

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

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

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

代码实现

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

我有写一部分凝视。

  1. //
  2. // main.cpp
  3. // BFS
  4. //
  5. // Created by Alps on 15/3/30.
  6. // Copyright (c) 2015年 chen. All rights reserved.
  7. //
  8. #include <iostream>
  9. #include <queue>
  10. #ifndef Vertex
  11. #define Vertex int
  12. #endif
  13. #ifndef NumVertex
  14. #define NumVertex 4
  15. #endif
  16. #define WHITE 0
  17. #define GRAY 1
  18. #define BLACK 2
  19. using namespace std;
  20. struct node{
  21. int val;
  22. int weight;
  23. node* next;
  24. node(int v, int w): val(v), weight(w), next(NULL){}
  25. };
  26. typedef node* VList;
  27. struct TableEntery{
  28. VList header;
  29. Vertex color;
  30. };
  31. typedef TableEntery Table[NumVertex+1];
  32. void InitTableEntry(Vertex start, Table T){ //init the Graph
  33. Vertex OutDegree = 0;
  34. VList temp = NULL;
  35. for (int i = 1; i <= NumVertex; i++) {
  36. scanf("%d",&OutDegree); // input the out degree of vertex
  37. T[i].header = NULL;
  38. T[i].color = WHITE;
  39. for (int j = 0; j < OutDegree; j++) {
  40. temp = (VList)malloc(sizeof(struct node));
  41. scanf("%d %d",&temp->val, &temp->weight);
  42. temp->next = T[i].header;
  43. T[i].header = temp;
  44. }
  45. }
  46. T[start].color = GRAY; //init the start vertex color to gray
  47. }
  48. void BFS(Vertex start, Table T){
  49. queue<Vertex> Q;
  50. Q.push(start);
  51. VList temp = NULL;
  52. while (!Q.empty()) { //if queue is not empty, then the bfs is not over
  53. temp = T[Q.front()].header; //find the front of the queue
  54. while (temp) { //if the front vertex has next vertex
  55. if (T[temp->val].color == WHITE) {
  56. Q.push(temp->val); //push the white vertex to queue
  57. T[temp->val].color = GRAY; //change the color to gray
  58. }
  59. temp = temp->next;
  60. }
  61. printf("%d ",Q.front()); //output the vertex
  62. T[Q.front()].color = BLACK; //then change color
  63. Q.pop();
  64. }
  65. }
  66. int main(int argc, const char * argv[]) {
  67. Table T;
  68. InitTableEntry(1, T);
  69. BFS(1, T);
  70. return 0;
  71. }

上面的代码就是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. TControl.GetDeviceContext会给图形控件建立新的坐标原点和建立新的剪裁区域

    这是取得DC句柄的其中一种方法(会重定义原点和建立新的剪裁区): function TControl.GetDeviceContext(var WindowHandle: HWnd): HDC; be ...

  2. Usaco 1.3.2 修理牛棚(Barn Repair)

      Barn Repair 题意:在一个夜黑风高,下着暴风雨的夜晚,农民约翰的牛棚的屋顶.门被吹飞了. 好在许多牛正在度假,所以牛棚没有住满. 剩下的牛一个紧挨着另一个被排成一行来过夜. 有些牛棚里有 ...

  3. uva 10129

    主要是求能否形成联通的欧拉回路 并查集+ 欧拉回路判断 一开始用dfs判断联通,死活A不出来,Wa了好多次………哭…… 并查集一次就AC了 感觉还是并查集代码好写一点, 因为dfs还要判断入口在哪里… ...

  4. jquery实现鼠标焦点十字效果

    系统开发时很多地方需要有焦点效果,例如:鼠标点击聚焦,地图定位,在图片上突出显示,焦点定位页面元素. 本小功能通过jquery和graphics二次开发,实现通过鼠标点击页面任何区域,聚焦当前点击位置 ...

  5. flask开发restful api

    flask开发restful api 如果有几个原因可以让你爱上flask这个极其灵活的库,我想蓝图绝对应该算上一个,部署蓝图以后,你会发现整个程序结构非常清晰,模块之间相互不影响.蓝图对restfu ...

  6. Lucene.Net 2.3.1开发介绍 —— 三、索引(二)

    原文:Lucene.Net 2.3.1开发介绍 -- 三.索引(二) 2.索引中用到的核心类 在Lucene.Net索引开发中,用到的类不多,这些类是索引过程的核心类.其中Analyzer是索引建立的 ...

  7. jQuery EasyUI API 中文文档 - 菜单按钮(menubutton)

    <html> <head> <script src="jquery-easyui/jquery.min.js"></script> ...

  8. 传智播客成都java培训中心秀就业

    传智播客成都java培训中心秀就业 2013年被称为"史上最难就业季",成都传智播客学员如何应对的呢? 成都传智播客的学员在工作经验上颇占优势,我们采用项目驱动式教学模式,具有多年开发实战经验及教学经 ...

  9. 【iOS发展-44】通过案例谈iOS重构:合并、格式化输出、宏观变量、使用数组来存储数据字典,而且使用plist最终的知识

    我们今天的情况下是第一个例子,下面的5一来通过切换页上一页下一页: (1)第一步,基本是以非常傻非常直接的方式来创建.这里用到的主要点有: --把对象变量设置为全局变量使得能够在其它方法中调用来设置它 ...

  10. jQuery选择

    1.基本的选择 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY29tZW9uc3RvbmU=/font/5a6L5L2T/fontsize/400/fil ...