回溯法与DFS

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

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

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

你可能感兴趣的:(算法知识)