关于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

转载于:https://www.cnblogs.com/lanceyu/p/9986832.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值