博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
图的俩种遍历方式(DFS,BFS)C++代码实现
阅读量:4070 次
发布时间:2019-05-25

本文共 748 字,大约阅读时间需要 2 分钟。

DFS,BFS

代码显示为输出连通集

算法时间复杂度:

采用邻接表存储图:DFS和BFS都为O(N+E)采用邻接矩阵存储:DFS和BFS都为O(N^2);

数据结构设计

/// @brief 顶点/// @param adjacencyList 邻接表struct vertex{    int id;    vector
adjacencyList;};vector
visited(N,false);vector
vertexList(N);

DFS

void dfs(int s,vector
&visited,vector
&path,vector
vertexList){ vector
v = vertexList[s].adjacencyList; for (int i=0; i

BFS

void bfs(int s,vector
&visited,vector
&path,vector
vertexList){ queue
q; q.push(s); while (!q.empty()) { int cur = q.front(); q.pop(); vector
v = vertexList[cur].adjacencyList; for (int i=0; i

转载地址:http://cehji.baihongyu.com/

你可能感兴趣的文章
《数据库系统概论》 第一章 绪论
查看>>
《数据库系统概论》 第二章 关系数据库
查看>>
《数据库系统概论》 第三章 关系数据库标准语言SQL
查看>>
SQL语句(二)查询语句
查看>>
SQL语句(六) 自主存取控制
查看>>
《计算机网络》第五章 运输层 ——TCP和UDP 可靠传输原理 TCP流量控制 拥塞控制 连接管理
查看>>
堆排序完整版,含注释
查看>>
二叉树深度优先遍历和广度优先遍历
查看>>
生产者消费者模型,循环队列实现
查看>>
PostgreSQL代码分析,查询优化部分,process_duplicate_ors
查看>>
PostgreSQL代码分析,查询优化部分,canonicalize_qual
查看>>
PostgreSQL代码分析,查询优化部分,pull_ands()和pull_ors()
查看>>
ORACLE权限管理调研笔记
查看>>
移进规约冲突一例
查看>>
IA32时钟周期的一些内容
查看>>
SM2椭圆曲线公钥密码算法
查看>>
获得github工程中的一个文件夹的方法
查看>>
《PostgreSQL技术内幕:查询优化深度探索》养成记
查看>>
PostgreSQL查询优化器详解之逻辑优化篇
查看>>
STM32中assert_param的使用
查看>>