深度优先搜索DFS
Posted ezoiHY
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了深度优先搜索DFS相关的知识,希望对你有一定的参考价值。
深度优先搜索也就是DFS,使我们oi竞赛中使用的最多的算法之一
我们今天就来看下这个神奇的算法
1.什么是DFS
事实上,深度优先搜索属于图算法的一种,英文缩写为DFS即Depth First Search.其过程简要来说是对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次
2.DFS有什么用
其实这个DFS往往用来遍历一幅图,在树剖、网络流等算法中会用到。它还可以用来求dfn序。以下代码就是求dfn序最普遍的写法。
void dfs(int now){
dfn[now]=tim++;
//do something
for(int i=0;i<edge[now].size();i++)
if(!vis[edge[now][i]])
dfs(edge[now][i]);
}
3.关于DFS的一些例题
以上是关于深度优先搜索DFS的主要内容,如果未能解决你的问题,请参考以下文章
数据结构与算法图遍历算法 ( 深度优先搜索 DFS | 深度优先搜索和广度优先搜索 | 深度优先搜索基本思想 | 深度优先搜索算法步骤 | 深度优先搜索理论示例 )
深度优先搜索 DFS(Depath First Search, DFS)