广度优先搜索递归C语言代码,C++实现广度优先搜索实例

本文详细介绍了广度优先搜索(BFS)算法的思想和C++实现,通过邻接表存储有向图,并展示了如何避免访问已访问过的顶点,最后分析了算法的空间和时间复杂度。
摘要由CSDN通过智能技术生成

本文主要叙述了图的遍历算法中的广度优先搜索(Breadth-First-Search)算法,是非常经典的算法,可供C++程序员参考借鉴之用。具体如下:

首先,图的遍历是指从图中的某一个顶点出发,按照某种搜索方法沿着图中的边对图中的所有顶点访问一次且仅访问一次。注意到树是一种特殊的图,所以树的遍历实际上也可以看作是一种特殊的图的遍历。图的遍历主要有两种算法:广度优先搜索(Breadth-First-Search)和深度优先搜索(Depth-First-Search)。

一、广度优先搜索(BFS)的算法思想

广度优先搜索类似于二叉树的层序遍历,它的基本思想就是:首先访问起始顶点v,接着由v出发,依次访问v的各个未访问过的邻接顶点w1,w2,…,wi,然后再依次访问w1,w2,…,wi的所有未被访问过的邻接顶点;再从这些访问过的顶点出发,再访问它们所有未被访问过的邻接顶点……依次类推,直到图中所有顶点都被访问过为止。

广度优先搜索是一种分层的查找过程,每向前走一步可能访问一批顶点,不像深度优先搜索那样有往回退的情况,因此它不是一个递归的算法。为了实现逐层的访问,算法必须借助一个辅助队列,以记录正在访问的顶点的下一层顶点。

3f450a7474a6611104796bd8466a54ce.png

如上图所示,为一个有向图,从顶点2开始广度优先遍历整个图,可知结果为2

广度优先搜索算法(BFS)是一种图论的经典算法,用于解决图的遍历问题。在广度优先搜索中,从给定的起始顶点开始,逐层地向外扩展,先访问距离起始顶点最近的顶点,再访问距离起始顶点稍远一点的顶点,以此类推,直到访问完所有可达的顶点。 在引用的代码中,作者使用C语言实现广度优先搜索算法代码中使用了一个二维向量`tree`来表示图,`flag`数组用于记录搜索到了节点i的第几个节点,`M`队列用于存储待访问的节点。算法通过不断从队列中取出节点,并将其相邻的节点加入队列中,直到队列为空为止。 具体的实现步骤如下: 1. 声明一个二维向量`tree`,用于表示图。在代码中,将图中的节点数设为9,通过循环生成树的结构。 2. 初始化数组`flag`,用于记录搜索到了节点i的第几个节点。 3. 声明一个队列`M`,用于存储待访问的节点。 4. 将起始节点加入队列`M`中。 5. 开始广度优先搜索算法: - 从队列`M`中取出第一个节点,并输出该节点。 - 遍历该节点的相邻节点,将其加入队列`M`中。 - 如果队列`M`不为空,继续执行上述步骤。 6. 输出结束。 以上是广度优先搜索算法C语言实现示例。你可以参考这段代码来理解和使用广度优先搜索算法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [C++广度优先搜索一本通习题](https://download.csdn.net/download/m0_54615144/86269542)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [广度优先搜索算法(附C++实现)](https://blog.csdn.net/m0_37772174/article/details/81188732)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值