0

0

C++怎么实现图的DFS遍历_C++递归与栈实现【搜索】

冰火之心

冰火之心

发布时间:2026-03-03 14:38:03

|

210人浏览过

|

来源于php中文网

原创

dfs递归易栈溢出,因系统栈空间有限,节点过万或邻接表未去重时尤其危险;需加visited数组、传const引用、检查空图,并在深度超10⁴时切迭代。

c++怎么实现图的dfs遍历_c++递归与栈实现【搜索】

DFS递归实现:为什么溢出比你想象中来得快

递归写法最直观,但实际项目里容易在深图或环图上崩掉。核心问题不是逻辑错,而是系统栈空间耗尽——尤其当节点数过万、邻接表没做去重时,std::stack 用得多,call stack 更吃紧。

  • 必须加访问标记数组(vector<bool> visited</bool>),否则自环或无向边会无限递归
  • 邻接表传参建议用 const vector<vector>>& graph</vector>,避免拷贝开销
  • 递归入口别直接从 0 开始硬写,先检查 graph.size() > 0,空图不调用
  • Windows 下默认栈只有 1MB,Linux 可能更小;超 10⁴ 层深度就该切迭代

示例片段:

void dfs(int u, const vector<vector<int>>& graph, vector<bool>& visited) {
    visited[u] = true;
    for (int v : graph[u]) {
        if (!visited[v]) dfs(v, graph, visited);
    }
}

DFS迭代实现:手动栈里藏着三个关键状态

迭代不是简单把递归函数体塞进 while 循环。真正难点在于:递归隐式维护了「当前节点」+「未处理的邻接点索引」,而手动栈必须显式存这两样,否则会漏边或重复访问。

  • 推荐用 stack<pair int>></pair>:first 是节点编号,second 是它在邻接表中的下一个待查下标
  • 每次 pop 后,先标记访问,再从 graph[u][idx] 开始遍历,把后续未访问邻居连同新 idx 压栈
  • 不能只压节点(stack<int></int>),否则无法知道“这个节点还有哪几个邻居没看”
  • 初始化时每个起点要压入 {start, 0},不是 {start, -1} —— 下标从 0 开始

无向图 vs 有向图:邻接表构造时最容易漏掉的边方向

DFS 本身不区分有向无向,但建图错了,遍历结果就全偏了。常见错误是读入无向边却只加单向边,导致一半节点根本进不来。

Qwen
Qwen

阿里巴巴推出的一系列AI大语言模型和多模态模型

下载
  • 无向图:每条输入边 u-v 必须同时执行 graph[u].push_back(v)graph[v].push_back(u)
  • 有向图:只加 graph[u].push_back(v),反向边不存在
  • 混合图?别手写,用 struct Edge { int to; bool is_directed; }; 加权或带属性时更要小心
  • 调试技巧:打印 graph[i].size() 看各节点度数是否符合预期

vector 的坑:它不是真正的容器

vector<bool></bool> 做访问标记很常见,但它其实是位压缩特化类,不支持取地址、迭代器行为异常,某些编译器下 visited[u] = true 可能不生效。

立即学习C++免费学习笔记(深入)”;

  • 生产环境优先用 vector<char></char>vector<int></int>,内存多占不到 1%,但行为确定
  • 如果坚持用 vector<bool></bool>,确保编译器版本 ≥ GCC 11 或 Clang 14,旧版有已知优化 bug
  • 千万别对 vector<bool></bool>&visited[i] 操作,会编译失败或运行时崩溃
  • 初始化别写 vector<bool>(n, false)</bool> —— 虽然语法合法,但部分 STL 实现里默认值语义不稳
实际跑起来,最常卡住的地方不在算法逻辑,而在建图是否完整、visited 类型是否可靠、以及递归深度是否真可控。这些细节一错,输出看起来像 DFS,其实只是碰巧扫到了一部分节点。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1665

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

395

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

1025

2025.04.24

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

104

2023.09.25

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

557

2023.09.20

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

910

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

599

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

3

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号