使用向量和队列实现BFS,按照CLRS算法在C程序中的实现
在CLRS书中,BFS算法使用向量和队列来描述。我们必须使用C++ STL来实现该算法。首先让我们看一下算法。
算法
BFS(G, s) −
begin for each vertex u in G.V - {s}, do u.color := white u.d := infinity u.p := NIL done s.color := green s.d := 0 s.p := NIL Q := NULL insert s into Q while Q is not null, do u = delete from Q for each v in adjacent to u, do if v.color = white v.color := green v.d := u.d + 1 v.p := u insert v into Q end if done u.color = dark_green done end
Example
的中文翻译为:示例
#include<iostream> #include<vector> #include<queue> using namespace std; vector<string> colour; vector<int> dist; vector<int> par; void addEdge(vector <int> g[], int u, int v) { //add edge to form the graph g[u].push_back(v); g[v].push_back(u); } void BFS(vector <int> g[], int s) { queue<int> q; q.push(s); //insert source dist[s] = 0; colour[s] = "gray"; while (!q.empty()) { int u = q.front(); //top element from queue, then delete it q.pop(); cout << u << " "; for (auto i = g[u].begin(); i != g[u].end(); i++) { if (colour[*i] == "white") { //white is unvisited node colour[*i] = "gray"; //gray is visited but not completed dist[*i] = dist[u] + 1; par[*i] = u; q.push(*i); } } colour[u] = "black"; //black is completed node } } void BFSAlgo(vector <int> g[], int n) { colour.assign(n, "white"); //put as unvisited dist.assign(n, 0); par.assign(n, -1); for (int i = 0; i < n; i++) if (colour[i] == "white") BFS(g, i); } int main() { int n = 7; vector <int> g[n]; addEdge(g, 0, 1); addEdge(g, 0, 2); addEdge(g, 1, 3); addEdge(g, 1, 4); addEdge(g, 2, 5); addEdge(g, 2, 6); BFSAlgo(g, n); }
输出
0 1 2 3 4 5 6
以上是使用向量和队列实现BFS,按照CLRS算法在C程序中的实现的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Laravel是一款非常流行的PHP开发框架,它提供了丰富的功能和便捷的开发方式,能够帮助开发人员快速构建稳定可靠的Web应用程序。在Laravel开发过程中,合理使用缓存与队列是十分重要的,本文将介绍一些注意事项以帮助开发人员更好地利用缓存与队列。一、合理使用缓存缓存的定义与作用缓存是一种将经常使用的数据临时存储在内存中的技术,能够极大地提高系统的响应速度

队列的死信队列和延迟队列在PHP与MySQL中的应用场景引言随着互联网应用变得越来越复杂,处理大量消息和任务的需求日益增长。队列作为一种解决方案,能够有效地实现任务的异步处理,提高系统的可伸缩性和稳定性。在队列的应用中,常见的两个概念是死信队列和延迟队列。本文将介绍这两个概念在PHP与MySQL中的应用场景,并提供具体的代码示例。死信队列的应用场景死信队列是

在CLRS书中,BFS算法使用向量和队列来描述。我们必须使用C++STL来实现该算法。首先让我们看一下算法。算法BFS(G,s)−begin foreachvertexuinG.V-{s},do u.color:=white u.d:=infinity u.p:=NI

队列在PHP与MySQL中的消息过滤和消息路由的实现方法随着互联网的快速发展,消息队列(MessageQueue)作为一种重要的通信机制,在Web开发中扮演着至关重要的角色。消息队列可以用于实现解耦、削峰填谷、异步处理等功能。本文将介绍在PHP与MySQL中如何实现消息过滤和消息路由,并提供具体的代码示例。消息队列消息队列是一种典型的"生产者-消费者"模型

队列的消息持久化和消息去重在PHP与MySQL中的应用场景队列是一种常见的数据结构,在软件开发中被广泛应用于异步消息处理、任务调度、日志收集等场景。其中,消息持久化和消息去重是队列的两个重要特性,能够保证消息的可靠性和数据的一致性。在PHP和MySQL中,队列的应用可以通过Redis作为消息中间件,用MySQL来存储和管理队列的元数据,具体示例如下所示。首先

介绍C++中的栈和队列栈和队列是C++中常用的数据结构,它们在程序中有着广泛的应用。本文将对栈和队列的概念、使用方法和应用场景进行详细介绍。一、栈的概念栈(Stack)是一种线性数据结构,它具有"先进后出"的特点。在栈中,越先进栈的数据,越靠近栈底;越后进栈的数据,越靠近栈顶。栈的主要操作有入栈(push)和出栈(pop)。入栈就是往栈里添加数据,而出栈

一个栈(Stack)是Vector类的子类,它代表了一个后进先出(LIFO)的对象堆栈。最后一个添加到堆栈顶部的元素(In)可以是从堆栈中首先移除的元素(Out)。队列(Queue)类扩展了Collection接口,并支持使用先进先出(FIFO)的插入和删除操作。我们也可以在下面的程序中使用队列来实现栈。示例importjava.util.*;publicclassStackFromQueueTest{ Queuequeue=newLinkedList();

队列在PHP与MySQL中的消息堆积和拥塞控制的处理方法随着互联网的迅猛发展,各种网站和应用程序的用户数量不断增加,对服务器的负载能力提出了更高的要求。在这种背景下,消息队列成为了一种常用的解决方案,用来解决高并发访问下的消息堆积和拥塞问题。本文将介绍队列在PHP与MySQL中的消息堆积和拥塞控制的处理方法,并给出具体的代码示例。在PHP中,我们可以使用Re
