深搜和广搜的概念和设计思想(贪心+动态规划+最大堆)

本文介绍了深度优先搜索(DFS)和广度优先搜索(BFS)的基本概念,强调它们不仅应用于图的搜索,而是通用的解决问题的思路。对于DFS,提到了递归和非递归实现,尤其是非递归方法通常结合动态规划和栈来实现。动态规划是将问题分解为子问题,并要求子问题最优解以达到整体最优。而贪心算法则是在每个步骤选择当前最优,适用于有最优子结构的问题。最大堆是一种特殊的树形数据结构,常用于优先队列,调整时间为O(log n)。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

广搜和深搜大多用于图的搜索,但是也不仅仅用于此,因为这是一种思想,所以应该理论上可以用于所有合适的数据结构类型。


深度优先搜索法有递归以及非递归两种设计方法。一般的,当搜索深度较小、问题递归方式比较明显时,用递归方法设计好,它可以使得程序结构更简捷易懂。当搜索深度较大时,当数据量较大时,由于系统堆栈容量的限制,递归容易产生溢出,用非递归方法设计比较好。


递归算法比较简单,这里就不讲了,主要想说说非递归思想:主要借助节点类型为队列的栈实现。也就说,“探左”和“探右”通过弹栈实现,通常要加入动态规划的思想。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值