深度优先搜索DFS
程序员文章站
2022-06-11 10:50:26
...
深度优先搜索也就是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]);
}