蓝桥杯省赛冲刺(3)广度优先搜索

广度优先搜索(Breadth-First Search, BFS)是一种在图或树等非线性数据结构中遍历节点的算法,它从起始节点开始,按层级逐步向外扩展,即先访问离起始节点最近的节点,再访问这些节点的邻居,然后是邻居的邻居,以此类推。BFS利用队列数据结构来实现这种层级顺序的遍历。以下是广度优先搜索的C语言实现及应用的详细介绍:

### **算法描述**

广度优先搜索遵循以下基本步骤:

1. **初始化**:定义一个标志数组(通常为布尔数组)来记录每个节点是否已被访问。对于无向图,初始化所有节点为未访问状态。

2. **选择起始节点**:从图中选择一个起始节点作为搜索起点。通常在无指定起点时,可以选择任意未访问节点作为起始点。

3. **访问节点**:标记当前节点为已访问,并执行与节点相关操作(如输出节点信息、计算节点属性等)。

4. **入队邻居**:将当前节点的所有未访问邻居节点加入队列。队列确保了节点按照层次顺序被访问。

5. **出队节点**:从队列中取出下一个节点(即最先进入队列的节点,也就是距离起始节点最近且未访问过的节点)。重复步骤3-4,直到队列为空,表示所有与起始节点可达的节点已被访问。

### **C语言实现**

下面是一个使用C语言实现广度优先搜索算法的示例,以遍历一个无向图(用邻接矩阵表示)为例:

```c

#include <stdio.h>

#include <stdbool.h>

#include <queue>

// 定义图的最大顶点数和边的关系类型

#define MAX_VERTEX_NUM 10

typedef int VRType;

// 定义图的邻接矩阵表示

VRType graph[MAX_VERTEX_NUM][MAX_VERTEX_NUM];

// 定义一个标志数组,记录节点是否已被访问

bool visited[MAX_VERTEX_NUM] = {false};

// 使用std::queue来存储待访问节点

std::queue<int> nodeQueue;

// 广度优先搜索函数

void bfs(int start_vertex) {

    // 标记起始节点为已访问,并将其加入队列

    visited[start_vertex] = true;

    nodeQueue.push(start_vertex);

    while (!nodeQueue.empty()) {

        // 取出队列头部的节点(距离起始节点最近且未访问过的节点)

        int current_vertex = nodeQueue.front();

        nodeQueue.pop();

        printf("Visited node: %d\n", current_vertex); // 输出节点信息

        // 遍历当前节点的所有邻居

        for (int i = 0; i < MAX_VERTEX_NUM; i++) {

            // 如果邻居节点未被访问且与当前节点存在连接

            if (!visited[i] && graph[current_vertex][i] != 0) {

                // 标记邻居节点为已访问,并将其加入队列

                visited[i] = true;

                nodeQueue.push(i);

            }

        }

    }

}

int main() {

    // 假设已填充了图的邻接矩阵graph

    // 选择一个起始节点,这里以节点0为例

    bfs(0);

    return 0;

}

```

在这个示例中,`bfs()` 函数接受起始节点编号作为参数,初始化队列并开始搜索过程。主函数 `main()` 调用 `bfs()` 以节点0为起始点启动搜索。

### **应用场景**

广度优先搜索在多个领域有广泛应用,包括但不限于:

- **图的连通性检测**:判断图中是否存在从一个节点到另一个节点的路径,同时可以确定两节点之间的最短路径(在所有边权重相等的情况下)。

- **社交网络中的朋友推荐**:查找与用户最近的人脉关系。

- **网络路由**:在网络中寻找最短路径(例如,IP路由表的构建)。

- **游戏AI**:在有限的行动空间内寻找最优或近似最优路径(如棋类游戏、迷宫求解等)。

- **网页抓取**:用于构建网站的目录结构或抓取特定深度的网页。

总之,广度优先搜索以其层级遍历的特性,适用于需要快速找到离起点最近节点及其路径,或解决最短路径问题(在边权相同的情况下)的情况。在C语言中,借助标准库提供的队列数据结构,可以方便地实现BFS算法。

9093b12e7cb8415e83a3794f3bf907f6.jpg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/810849.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

异常处理java

在Java中&#xff0c;异常处理可以使用"throws"关键字或者"try-catch"语句。这两种方法有不同的用途和适用场景。 "throws"关键字: 在方法声明中使用"throws"关键字&#xff0c;表示该方法可能会抛出异常&#xff0c;但是并不立即处理…

python脚本一键删除匹配项的所有key

1、安装redis模块 pip3 install redis Looking in indexes: http://mirrors.cloud.aliyuncs.com/pypi/simple/ Collecting redisDownloading http://mirrors.cloud.aliyuncs.com/pypi/packages/bb/f1/a384c5582d9a28e4a02eb1a2c279668053dd09aafeb08d2bd4dd323fc466/redis-5.0…

有关格式输入输出的问题

对于格式输入输出问题&#xff0c;我们最好用c语言编写代码&#xff01;&#xff01;&#xff01; 成绩统计 难点&#xff1a;格式化输出 #include <cstdio> using namespace std; typedef long long ll;ll n,score,a,b;int main() {//及格>60 优秀>85 求及格率…

变更docker的缓存路径

承接上一篇文章&#xff0c;定期清理docker&#xff0c;仍感觉有些累&#xff0c;这个变更一下缓存路径&#xff0c;可以根本解决问题。 linux磁盘清理_docker/overlay2爆满_linux overlay目录满了-CSDN博客 当然&#xff0c;变更docker的缓存路径&#xff0c;也可以使用上一…

mysql题目1

tj11: ​ select * from t_student where grade 大一 and major 软件工程 ​ tj12: SELECTt_student.name, count(t_choice.cid)FROMt_choiceINNER JOINt_courseON t_choice.cid t_course.idINNER JOINt_studentON t_choice.sid t_student.id GROUP BYt_choice.sid HAVIN…

PyTorch神经网络打印存储所有权重+激活值(运行时中间值)

很多时候嵌入式或者新硬件需要纯净的权重模型和激活值&#xff08;运行时中间值&#xff09;&#xff0c;本文提供一种最简洁的方法。 假设已经有模型model和pt文件了&#xff0c;在当前目录下新建weights文件夹&#xff0c;运行最后三行代码&#xff0c;就可以得到模型的权重&…

《疯狂java讲义》Java AWT图形化编程中文显示

《疯狂java讲义》第六版第十一章AWT中文没有办法显示问题解决 VM Options设置为-Dfile.encodinggbk 需要增加变量 或者这边直接设置gbk 此外如果用swing 就不会产生这个问题了。

京东采集器使用教程 京东商家爬虫软件分享

京东采集器是一款功能强大的京东商家爬虫软件&#xff0c;可以帮助用户快速采集京东商家的商品信息&#xff0c;并提供丰富的数据分析功能。 第一步&#xff1a;安装及配置 首先&#xff0c;你需要下载并安装京东采集器软件。下载完成后&#xff0c;双击安装文件并按照提示完…

YOLOv8最新改进系列:融合最新顶会提出的HCANet网络中卷积和注意力融合模块(CAFM),有效提升小目标检测性能,大幅度拉升目标检测效果!遥遥领先!

YOLOv8最新改进系列&#xff1a;YOLOv8最新改进系列:融合最新顶会提出的HCANet网络中卷积和注意力融合模块(CAFM)&#xff0c;有效提升小目标检测性能&#xff0c;大幅度拉升目标检测效果&#xff01;遥遥领先&#xff01; B站全文戳这里&#xff01; 详细的改进教程以及源码…

ZGC的介绍

背景 在jdk17中已经将ZGC从实验性产品升级到正式产品功能&#xff0c;达到亚毫秒级停顿&#xff0c;毫不留情地将parallel和G1拉开了数量级的差别&#xff0c;无论是平均停顿还是最大停顿时间都能毫不费劲地控制在10ms内。 《深入理解Java虚拟机》在书中这样定义&#xff1a;Z…

Python3.7编程之病毒

基础篇 什么是病毒 病毒&#xff0c;指的是一些通过非法手段获取系统的一些权限&#xff0c;然后进行破坏或者盗取。 病毒分为两类&#xff1a; 1、破坏型 这类病毒往往会将系统弄的乱七八糟&#xff0c;比如把你的U盘删光&#xff0c;把你的系统背景调成黑客图片&#xff0c…

CorelDRAW苹果版提示请重新连接具有文件位置的设备...的解决方法

今天小编想更新一下CorelDRAW2024苹果版&#xff0c;但升级完成依次提示“请重新连接具有文件位置的设备&#xff0c;或选择新文件夹。同时&#xff0c;内容将保存在Corel 默认位置。您可以在恢复文件位置之后移动内容”和“尝试重新启动计算机和应用程序。如果这些操作还是不能…

python 的join函数

join函数是一个对字符串处理的函数 字符串.join(str)的含义是把字符串加入到str的每一个间隙里面 如 str1234 ,.join(str) #打印的结果为 1,2,3,4

【03709】24年4月马克思主义基本原理概论考前密训—选择/简答题-2

目录 1.习题精析 2.高频考点(简答)— 社会革命和社会改革的区别

python划分数据集时出现KeyError: ‘instruction‘错误

今天在将json文件划分数据集时出现了KeyError: instruction错误&#xff0c;由于数据量比较大&#xff0c;所以在浏览了部分数据后以为结构没有问题&#xff0c;这是一部分的数据结构 {"instruction": "描述面向对象编程&#xff08;OOP&#xff09;的原则。&qu…

linux下的常用压缩格式及压缩命令

目录 linux下的常用压缩格式及压缩命令 一、tar打包工具 二、gzip压缩工具 三、bzip2压缩工具 四、其他格式的压缩和解压缩 在linux下常用的压缩格式有&#xff1a;.tar、.tar.bz2、.tar.gz 不同的压缩格式使用的打包工具及压缩命令也不同。以下简要介绍常用的压缩命令。…

逆向案例十九——某音乐搜索页面参数多文件webpack加密,采用全复制加补环境的做法。

网址&#xff1a;搜索 - QQ音乐-千万正版音乐海量无损曲库新歌热歌天天畅听的高品质音乐平台&#xff01; 进行搜索找到数据包&#xff1a; 发现载荷有加密参数sign: 在下方搜索框搜索sign:,进入js加密文件 进入js文件找到加密位置&#xff1a; sign由i赋值&#xff0c;在前面…

题目 2694: 蓝桥杯2022年第十三届决赛真题-最大数字【暴力解法】

最大数字 原题链接 &#x1f970;提交结果 思路 对于每一位&#xff0c;我我们都要尽力到达 9 所以我们去遍历每一位, 如果是 9 直接跳过这一位 如果可以上调到 9 我们将这一位上调到 9 &#xff0c;并且在a 中减去对应的次数 同样的&#xff0c;如果可以下调到 9&#xff0c;我…

学习笔记——C语言基本概念栈和队列——(14)

本次笔记是C语言的最后学习内容。 1、栈 特点&#xff1a;先进后出 堆栈又名栈&#xff08; stack&#xff09; &#xff0c; 它是一种运算受限的线性表。 限定仅在表尾进行插入和删除操作的线性表。 这一端被称为栈顶&#xff0c; 相对地&#xff0c; 把另一端称为栈底。 向…

如何通过OceanBase V4.2的复制表,提升数据库性能

引言&#xff1a; 复制表是OceanBase数据库中一种特殊的表&#xff0c;本文将介绍其基本定义与应用方法。复制表&#xff0c;能够在任意一个处于“健康”状态的副本上&#xff0c;获取到数据的最新变更。对于写入操作不频繁&#xff0c;但对读取操作的延迟和负载均衡有较高要求…