0x22 深度优先搜索

0x22 深度优先搜索

深度优先搜索(DFSDepth First Search),顾名思义,就是按照深度优先的顺序对"问题状态空间"进行搜索的算法。在0x00章中,我们多次把一个问题的求解看做对问题状态空间的遍历与映射。从本章起,我们可以进一步把"问题空间"类比成为一张图,其中的状态类比为节点,状态之间的联系与可达性就用图中的边来表示,那么使用深度优先搜索算法求解问题,就相当于在一张图上进行深度优先遍历。

深度优先搜索与"递归"和"栈"密切相关。我们倾向于认为"递归"是与递推相对的一种单纯的遍历方式,除了搜索之外,还有许多算法都可以用递归实现。而"深搜"是一类包括遍历形式、状态记录与检索、剪枝优化等算法整体设计的统称。

在研究深度优先搜索算法之前,我们先来定义该过程产生的"搜索树 "结构。在对图进行深度优先遍历处于 x x x点,对于某些边 ( x , y ) (x,y) (x,y), y y y是一个尚未访问过的节点,程序从 x x x成功进入了更深层的对 y y y的递归;对于另外一些边 ( x , y ) (x,y) (x,y), y y y已经被访问过,从而程序考虑其他分支。我们称所有点(问题空间中的状态)与成功发生递归的边(访问两个状态之间的移动)构成的树为一棵"搜索树"。整个深搜算法就是就基于该搜索树完成的------为了避免重复访问,我们对状态进行记录和检索;为了使程序更加高效,我们提前减除搜索树上不可能是答案的子树和分支,不去进行遍历。

我们在0x03节中使用递归实现的指数型、排列型和组合型枚举,其实就是深搜的三种简单的形式。与之相关的子集和问题、全排列问题、N皇后问题 等都是可以用深搜求解的经典NPC问题。

相关推荐
@卞1 小时前
从零实现一个高并发内存池(1)--- 项目介绍
c++
wjlnew1 小时前
c++中的内存管理:栈,堆及RALL机制
c++
无限进步_1 小时前
【C语言】用队列实现栈:数据结构转换的巧妙设计
c语言·开发语言·数据结构·c++·链表·visual studio
Xの哲學1 小时前
从硬中断到 softirq:Linux 软中断机制的全景解剖
linux·服务器·网络·算法·边缘计算
生信碱移2 小时前
单细胞空转CNV分析工具:比 inferCNV 快10倍?!兼容单细胞与空转的 CNV 分析与聚类,竟然还支持肿瘤的亚克隆树构建!
算法·机器学习·数据挖掘·数据分析·聚类
Brduino脑机接口技术答疑2 小时前
TDCA 算法在 SSVEP 场景中:Padding 的应用对象与工程实践指南
人工智能·python·算法·数据分析·脑机接口·eeg
keep_learning1113 小时前
Z-Image模型架构全解析
人工智能·算法·计算机视觉·大模型·多模态
千里马-horse3 小时前
TypedArrayOf
开发语言·javascript·c++·node.js·napi
点云SLAM3 小时前
Boost中Graph模块中boost::edge_capacity和boost::edge_capacity_t
数据库·算法·edge·图论·最大团·最大流算法·boost库使用
YIN_尹3 小时前
【C++11】lambda表达式(匿名函数)
java·c++·windows