高级搜索之迭代加深算法详解
可能很多初学者看到了迭代加深搜索这个名字就感觉“哇,好高级啊,学起来一定很复杂。”
但是事实却不是这样,只要你有过BFS和DFS的基础,理解起来其实是非常容易的。
为了形象地解释迭代加深搜索(IDDFS,Iterative Deepening Depth-first Search。网上找了一下,发现并没有这个全称。)
从图中可以看出,从起点开始搜索。使用DFS,搜到的第一个解便是X3。而使用BFS,搜到的第一个解便是X2。但目前的最优解是X1。尽管两种方法最终都可以搜到解X1,但却无法保证最优的时间复杂度。
迭代加深搜索(IDDFS)就这样诞生了。本质上它其实是给DFS加了一个限制。我们都知道DFS有层数这个概念。IDDFS便规定了一个层数,让DFS只能在这一个规定的层数里进行。
比如我们规定DFS只能在上图的深度为1的地方进行,很明显它便可以轻松地搜索的了最优解。
于是便可以得出IDDFS基本的框架:
void iddfs(层数参数) {
if(层数>规定最大层数) return ;
进行搜索......
}
int main() {
for(从一开始枚举规定最大层数) {
iddfs(1);
}
}
posted on 2019-04-25 13:39 MisakaMKT 阅读(2055) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏