DFS及其剪枝

【深度优先搜索】

深度优先搜索,是从初始状态起,利用一定的规则生成搜索树,寻找下一层任一个结点,检查是否出现目标状态,若未出现,以此状态利用规则生成再下一层任一个结点,再检查,重复过程一直到叶节点(即不能再生成新状态节点),当它仍不是目标状态时,回溯到上一层结果,取另一可能扩展搜索的分支。采用相同办法一直进行下去,直到找到目标状态为止。

【剪枝】

剪枝,就是减小搜索树规模、尽早排除搜索树中不必要的分支的一种手段。形象地看,就好像剪掉了搜索树的枝条,故称之为“剪枝”。在深度优先搜索中,有以下几类常见的剪枝方法:

1.优化搜索顺序

  在一些搜索问题中,搜索树的各个层次、各个分支之间的顺序不是固定的。不同的搜索顺序会产生不同的搜索树形态,其规模大小也相差甚远。

  大部分情况下,优先搜索分支较少的节点。

2.排除等效冗余

  在搜索过程中,如果我们能够判定从搜索树的当前节点上沿着某几条不同分支到达的子树是等效的,那么只需要对其中的一条分支执行搜索。

3.可行性剪枝

  在搜索过程中,及时对当前状态进行检查,如果发现分支已经无法到达递归边界,就执行回溯。这就好比我们在道路上行走时,远远看到前方是一个死胡同,就应该立即折返绕路,而不是走到路的尽头再返回。

  某些题目条件的范围限制是一个区间,此时可行性剪枝也被称为“上下界剪枝”。

4.最优性剪枝

  在最优化问题的搜索过程中,如果当前花费的代价已经超过了当前搜到的最优解,那么无论采取多么优秀的策略到达递归边界都不可能更新答案。此时可以停止对当前分支的搜索,执行回溯。

5.记忆化

  可以记录每个状态的搜索结果,在重复遍历一个状态时直接检索并返回。这就好比我们对图进行深度优先遍历时,标记一个节点是否已经被访问过。

【例题】

  • Codeup 问题 A: 全排列(入门):点击这里
  • AcWing 842. 排列数字(入门):点击这里
  • HDU 2553 N皇后问题(DFS剪枝、多组样例打表):点击这里
  • AcWing 843. n-皇后问题(输出棋盘):点击这里
发布了844 篇原创文章 · 获赞 135 · 访问量 15万+

猜你喜欢

转载自blog.csdn.net/qq_42815188/article/details/105100128
今日推荐