回溯法与DFS

回溯法 = DFS + 剪枝
回溯法采用的是深度优先搜索的策略,当搜索到解空间树的某一结点时,用约束条件判断对该结点是否需要剪枝,如果结点不可行需要剪枝,则跳过以当前结点为根节点的子树的搜索,回溯到父结点;否则,继续按DFS策略搜索子树。

单纯的DFS以深度为关键词进行搜索时,不会对约束条件进行判断,而是在搜索完成(到达边界)时才会判断是否满足约束条件,进而判断是否形成一个可行解。

例如DFS求解01背包问题,深度优先搜索物品的过程中没有判断已选物品是否超过背包最大容量,而是在所有物品遍历完成后才判断。当然可以在搜索的过程中对每个结点进行背包容量约束条件判断(剪枝),这就相于跳过当前子树,返回父结点,进而搜索另一子树,这就是回溯法(=DFS+剪枝)。剪枝形成了回溯,子树剪掉,返回父结点,进入另一子树。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值