0x23 剪枝

0x23 剪枝

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

1.优化搜索顺序

在一些搜索问题中,搜索树的各个层次、各个分支之间的顺序不是固定的。不同的搜索顺序会产生不同的搜索树形态,其规模大小也相差甚远。例如:在数独问题中,优先搜索"能填的合法数字最少的位置。

2.排除等效冗余

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

初学者一定要避免重叠、混淆"层次"与"分支",避免遍历若干颗覆盖同一状态空间的等效搜索树。

3.可行性剪枝

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

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

4.最优性剪枝

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

5.记忆化

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

相关推荐
qq_334903152 分钟前
高性能网络协议栈
开发语言·c++·算法
光电笑映4 分钟前
STL 源码解剖系列:map/set 的底层复用与红黑树封装
c语言·数据结构·c++·算法
阿贵---6 分钟前
模板编译期循环展开
开发语言·c++·算法
2601_954023666 分钟前
Beyond the Hype: Deconstructing the 2025 High-Performance Stack for Agencies
java·开发语言·算法·seo·wordpress·gpl
沉鱼.446 分钟前
滑动窗口问题
数据结构·算法
ysa05103012 分钟前
二分+前缀(预处理神力2)
数据结构·c++·笔记·算法
2401_8331977314 分钟前
嵌入式C++电源管理
开发语言·c++·算法
灰色小旋风17 分钟前
力扣22 括号生成(C++)
开发语言·数据结构·c++·算法·leetcode
寒月小酒18 分钟前
3.23 OJ
数据结构·c++·算法
2501_9249526919 分钟前
模板编译期哈希计算
开发语言·c++·算法