关于DFS的理解

DFS(深度优先搜索)相当于暴力寻找有效解的过程

如果把多种情况写成一个树的方式

那么DFS的实质就是遍历所有分枝来寻找最优解

而DFS中遍历所有解的方式采用了我们称之为回溯法的东西

 

如图所示

图中的搜索顺序为从A到B到D

然后在向回退一步

此时原来D的地方因为被访问过

所以不选择访问之

选择访问E,之后访问G

因为E和G被访问过

所以我们需要往回走到A

此时向C开始访问

具体过程很好理解

做题时只需要每一次判断下是否满足条件即可

下面上@Armin 给我们写的关于DFS相当好的模板

想看@Armin 博客的同学请点击左边的友链哦

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------

 1 void dfs(int )
 2 {
 3     if(到达终点状态)
 4     {
 5         ...//根据题意添加
 6         return; 
 7     }
 8     
 9     for(所有方式)
10     {
11         if(扩展方式所达到状态合法)
12         {
13             修改操作;//根据题意来添加
14             标记;//访问过这个元素
15             dfs();
16             还原标记;
17             //是否还原标记根据题意
18             //如果加上就是回溯法 
19         }
20     }
21 }

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------

关于回溯法的话主要还是根据题意

如果题意仅仅要求判断是否有解的话

就没有必要再去回溯了

浪费时间

Notes:其实因为DFS是一个递归的过程

其实还真的不是那么好懂

博主整整看了两天才差不多理解

有疑问的欢迎在评论区留言

01:27:21  2018-11-20  Author:LanceYu

posted @ 2018-11-20 01:29  微生泽驰  阅读(1649)  评论(0编辑  收藏  举报