算法学习 - 图的广度优先遍历(BFS) (C++)

时间:2022-06-20 10:27:26

广度优先遍历

广度优先遍历是非经常见和普遍的一种图的遍历方法了,除了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. 图的深度优先遍历&lpar;DFS&rpar;和广度优先遍历&lpar;BFS&rpar;

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

  9. 图的深度优先遍历&lpar;DFS&rpar;和广度优先遍历&lpar;BFS&rpar;算法分析

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

随机推荐

  1. &lbrack;LintCode&rsqb; Sort List 链表排序

    Sort a linked list in O(n log n) time using constant space complexity. Have you met this question in ...

  2. nextAll&lpar;&lbrack;expr&rsqb;&rpar;

    描述: 给第一个div之后的所有元素加个类 HTML 代码: <div></div><div></div><div></div> ...

  3. Table of Contents ---BCM

    Table of ContentsAbout This Document................................................................ ...

  4. POJ3281 Dining&lpar;拆点构图 &plus; 最大流)

    题目链接 题意:有F种食物,D种饮料N头奶牛,只能吃某种食物和饮料(而且只能吃特定的一份) 一种食物被一头牛吃了之后,其余牛就不能吃了第一行有N,F,D三个整数接着2-N+1行代表第i头牛,前面两个整 ...

  5. js更新页面,随机更新数字

    代码1: <script> function getRandom(){ var i = Math.random()*40+160; document.getElementById(&quo ...

  6. 基于ADODBX对数据库的CURD

    学asp.net也有一个多星期了,之前对这个一无所知,也不知道怎么去找一些相关的资料去学习,不懂了就问问别人这个怎么做,那个怎么写,要不是有jsp和php的基础,估计还得弄上好长的时间来学习.记录一下 ...

  7. intellij idea该插件开发摘要

    最近在做一个intellij idea插件,功能是读取表和数据库信息字段和预先定义的模板来生成代码文件(实体,service,springmvc该controller,freemark文件等). 找了 ...

  8. 【开源&period;NET】轻量级内容管理框架Grissom&period;CMS(第三篇解析配置文件和数据以转换成 sql)

    该篇是 Grissom.CMS 框架系列文章的第三篇, 主要介绍框架用到的核心库 EasyJsonToSql, 把标准的配置文件和数据结构解析成可执行的 sql. 该框架能实现自动化增删改查得益于 E ...

  9. 【转】CPU与内存的那些事

    下面是网上看到的一些关于内存和CPU方面的一些很不错的文章. 整理如下: 转: CPU的等待有多久? 原文标题:What Your Computer Does While You Wait 原文地址: ...

  10. 错误:You can&&num;39&semi;t specify target table &&num;39&semi;xxx&&num;39&semi; for update in FROM clause的解决

    问题: 今天在MySQL数据库删除重复数据的时候遇到了一个问题.如下脚本: DELETE FROM tempA WHERE tid IN ( SELECT MAX(tid) AS tid FROM t ...