A*搜索算法

简介

A* 算法是基于BFS的一种入门级启发式搜索算法,就是将BFS的队列改为基于估价的优先队列,可以快速地找到答案。

算法流程伪代码描述

//优先队列为小根堆
WHILE 优先队列不为空
	取出队头并扩展
	将扩展节点以估价值+当前值为优先级入队
END WHILE

注意事项

估价函数越接近真实值算法越优,但一定不能大于真实值,否则可能会一直进入错误的迭代而得到错误的答案(即真正可以迭代出答案的节点可能被一直压在优先队列中无法取出)。

特别的,当估价函数恒为0时,A* 算法与普通的优先队列优化BFS无异。

A* 版k短路算法

这里使用A* 求k短路,但不是最优方法,因为A* 会扩展出很多无用节点。

算法流程伪代码描述

//优先队列为小根堆,以第二个成员变量为优先级
//c[x]为x到所求节点的最短路
//w[x,y]为从x到y的边权
WHILE 优先队列不为空
	取出队头节点{x,d}
	cnt[x]++
	IF x是所求节点 THEN
		IF cnt[x] == k THEN
			返回 d
		END IF
	END IF
	FOR y与x相连
		IF cnt[y] == k THEN
			CONTINUE
		END IF
		新建节点{y,d+w[x,y]+c[y]}
		节点入队
	NEXT y
END WHILE

例题

洛谷P2483 【模板】k短路([SDOI2010]魔法猪学院)

注意事项

这道题A会被卡第11个点的空间,A可得92分(共12个时间点)。
这道题需在程序中计算出k的最大值
m a x { k } = E / c [ 1 ] max \left \{ k \right \} = E/c[1] max{k}=E/c[1]
c[1]是从第一个元素到第n个元素的最短路。

每次求出第i短路时将E减去该短路长度,若某次取出节点的已求得的路径长度大于E则算法返回。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: A*搜索算法是一种常用于路径规划的启发式搜索算法,其在A搜索算法的基础上增加了一项启发式函数,用于评估当前节点到目标节点的距离。相比于A搜索算法,A*搜索算法具有以下优势: 1. 更快的搜索速度:由于A*搜索算法通过引入启发式函数来优化搜索方向,因此可以更快地找到最短路径。 2. 更少的搜索次数:相比于A搜索算法,A*搜索算法可以减少搜索次数,从而提高搜索效率。 3. 更小的搜索空间:由于A*搜索算法能够快速找到最短路径,因此搜索空间也会更小,从而减少计算量。 4. 更好的可扩展性:A*搜索算法可以适应不同的问题类型,因此可以更好地扩展到其他领域。 总之,A*搜索算法相比于A搜索算法可以更快、更高效地找到最短路径,适用于许多实际问题的求解。 ### 回答2: A*搜索算法相比于A搜索算法更加优越的地方在于它引入了启发式函数(heuristic function)来评估搜索的方向和效果。 首先,A*算法是一种综合了广度优先搜索和贪婪搜索策略的启发式搜索算法。它在搜索过程中不仅考虑了每一步的代价(如路径长度),还通过启发式函数估计当前节点到目标节点的代价。这样,A*算法能够智能地选择最有可能达到目标的节点进行搜索,大大提高了搜索效率。 其次,启发式函数的引入使得A*算法具有了考虑问题的全局信息的能力。通过启发式函数,A*算法可以利用先前的搜索经验,尽可能直观地指导后续的搜索方向,并减少不必要的搜索步骤。相比于A搜索算法,A*算法搜索的过程中更加聪明、迅速。 此外,A*算法还具备了一定的最优性质。在有穷状态空间中,如果启发式函数是一致的(admissible),即不会高估任何节点到目标节点的代价,那么A*算法可以保证找到最优解。这意味着,相较于A搜索算法,A*算法不仅更快地找到解决方案,而且还能保证这个解决方案是最优的。 综上所述,A*搜索算法相比于A搜索算法更好的地方在于它引入了启发式函数,使得搜索方向更为智能和高效,具备全局信息考虑的能力,并能够在满足一定条件下找到最优解决方案。 ### 回答3: A*搜索算法比A搜索算法好在于它综合了两个重要的因素:启发函数和代价函数。启发函数用于估计从当前节点到目标节点的预期代价,而代价函数则用于估计从起始节点到当前节点的实际代价。通过这两个函数的结合,A*搜索算法能够更加智能地选择扩展节点,从而提高搜索效率和搜索结果的质量。 首先,相较于A搜索算法,A*算法采用了启发函数的引导。启发函数提供了对问题的某些特征的启示,可以帮助算法优先选择那些看似最有希望的节点进行扩展。这也意味着A*算法能够更快地接近目标节点,减少不必要的搜索开销。 其次,A*算法还结合了代价函数的信息,使得搜索过程更加准确。代价函数可以根据实际情况考虑节点之间的距离、代价等因素,从而更好地估计路径的实际代价。这使得A*算法能够对节点进行更加精细的排序,从而更快地找到最优解。 此外,A*算法还通过采用优先队列的方式管理节点的扩展顺序,进一步提高了搜索效率。优先队列可以根据节点的启发函数值(即节点到目标节点的预期代价)进行排序,使得具有较低启发函数值的节点优先被扩展。这样可以尽早地找到更优解,并且减少了不必要的节点扩展。 综上所述,A*搜索算法相较于A搜索算法的优势在于它综合了启发函数和代价函数,能够更智能地选择节点扩展顺序,并更准确地估计路径的实际代价。这使得A*算法搜索效率和搜索结果质量上都有明显的提升。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值