深度优先搜索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)

LeetCode 988:回溯和深度优先搜索(DFS)的区别

DFS(深度优先搜索)

深度优先搜索和广度优先搜索的简单对比

基本算法——深度优先搜索(DFS)和广度优先搜索(BFS)