ChatGPT体验 AI绘画体验
C++深度优先搜索模板
提问人:ppw_c230804 时间:2024-05-29 公开状态:

提问人:ppw_c230804 时间:2024-05-29 公开状态:


深度优先搜索(DFS)是一种用于遍历或搜索树或图的算法。在执行深度优先搜索时,它沿着一个分支走到底,然后回溯。以下是使用 C++ 实现深度优先搜索的一个基本模板:
```cpp
#include <iostream>
#include <vector>
using namespace std;
// 函数模板,用于执行深度优先搜索
void DFS(int node, vector<int> adj[], vector<bool>& visited) {
// 当前节点标记为已访问
visited[node] = true;
cout << node << " ";
// 遍历当前节点的所有邻接节点
for (int i = 0; i < adj[node].size(); i++) {
int nextNode = adj[node][i];
// 如果邻接节点未被访问,则递归地进行DFS
if (!visited[nextNode]) {
DFS(nextNode, adj, visited);
}
}
}
int main() {
// 假设有5个节点的图
int nodes = 5;
// 创建图的邻接表表示
vector<int> adj[nodes];
// 添加边,例如:
// 节点0与节点1相连
adj[0].push_back(1);
// 节点1与节点2相连
adj[1].push_back(2);
// 节点2与节点0和节点3相连
adj[2].push_back(0);
adj[2].push_back(3);
// 节点3与节点4相连
adj[3].push_back(4);
// 访问数组,初始所有节点都未被访问
vector<bool> visited(nodes, false);
// 从节点0开始执行DFS
DFS(0, adj, visited);
return 0;
}
```
在这个模板中,我们使用了一个邻接表来表示图,其中`adj`是一个数组,数组的每个索引代表一个节点,而对应的数组元素是一个包含与该节点相连的所有节点列表的`vector`。我们还使用了一个`visited`数组来跟踪哪些节点已经被访问过,以避免重复访问。
在`DFS`函数中,我们首先将当前节点标记为已访问,并打印出来。然后,我们遍历当前节点的所有邻接节点,并对每个未被访问的邻接节点递归地调用`DFS`函数。
在`main`函数中,我们创建了一个示例图,并从节点0开始执行深度优先搜索。这个模板可以根据你的具体需求进行调整,例如处理不同的图结构或者执行不同的操作。
<<提问分享>>
pyttsx3合成语言到文件pyttsx3安装、入门、进阶示例
逆元在信息学竞赛中的应用
ubuntu20.04安装英伟达显卡驱动
生活中能用数组解决的实例详解
与二维数组相关的基础算法实例
与一维数组相关的基础算法解析
轻量级markdown渲染前端框架及其使用方法
python将base64转jpg文件
python将base64转图像
RTX3060Ti显卡详细参数
RTX3060显卡详细参数
RTX2080Ti显卡详细参数
MySQL备份所有数据库的命令
mysql备份恢复数据库命令总结
如何提高打字速度?
python执行命令,并限制时间和内存
python获取excel表中C13单元格的各个属性
python读取excel中成绩工作表的第3行第四列单元格
python读取excel表格信息示例
读伤仲永有感,500字
Linux系统用户登录验证方式可以用MySQL吗?如何配置?
ubuntu重装系统,用户密码等信息如何备份与恢复
Ubuntu16.04安装VNC桌面环境和火狐浏览器
用ps命令输出指定用户的详细进程
用linux命令统计每个用户内存使用量
Ubuntu配置3389远程桌面连接本地用户登录
Ubuntu配置3389远程桌面连接
Linux常用命令及其用法讲解
MySQL常用字符串函数及其用法
生成对抗网络入门讲解与应用举例
file_get_contents带cookies发送https请求
nginx配置ssl证书
举个简单的例子,告诉我什么是期望
二叉排序树的原理讲解及其C++代码
nginx通过url重写实现伪静态示例
php用正则表达式匹配所有5位数
php用正则表达式替换行头空格
C++中multimap怎么用?
DevC++配置C++11、C++14编译环境
固态硬盘中的QLC、MLC、TLC
Linux系统中怎么修改密码
python程序设计顺序结构的有趣例子
使用python写一个小学生能实现的游戏
使用python进行人脸识别的原理及简单代码实现
使用python进行文本分类的原理及简单代码实现
详细介绍OpenAI中的CLIP,最好有代码
OpenAI所有接口介绍
OpenAI各种接口介绍及其用法
参加信息学竞赛,从小学几年级开始学比较合适?