高级搜索之迭代加深算法详解

可能很多初学者看到了迭代加深搜索这个名字就感觉“哇,好高级啊,学起来一定很复杂。”
但是事实却不是这样,只要你有过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);
	}
}

附:各种数论模板:

卡常必备!快速读入

int read() {
    int s=0,f=1;char a=getchar();
    while(a<'0' || a>'9') { if(a=='-') f=-1; a=getchar(); }
    while(a>='0' && a<='9') { s=s*10
  • 2
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值