A*算法

这两天学习了A*算法,总结记录一下,方便以后学习复习。(写到一半忽然崩掉,,,心态炸了)

A*算法

要了解A*算法,首先需要了解什么是启发式算法:启发式算法即一种在基于经验和预测,通过启发函数预测当前实例的成本,从而找到最优实例的方法,其算法效率与启发函数息息相关,启发函数越是接近真实值,那么算法的效率就越高。

A*算法,A*(A-Star)算法是一种静态路网中求解最短路径最有效的直接搜索方法,也是解决许多搜索问题的有效算法。算法中的距离估算值与实际值越接近,最终搜索速度越快。A*算法通过启发函数计算到各个节点的估算成本,依次取其中成本最小的节点,最终能够找到最优路径。A*算法的启发函数为:F=G+H

F:即对当前路径的估算成本。

G:即从起点到当前节点的路径距离或是成本代价。

H:即从当前节点到目标节点的估算成本,,可采用曼哈顿距离、切比雪夫距离和欧几里距离等(一般采用曼哈顿距离)。

A*算法的实现

A*算法的实现如下:从起点开始,搜索能够从起点到达的所有结点,并计算各个节点的估算成本F,然后将其全部放入open表中(为了方便后续找到最优路径,应该维护一个有序表,能够方便找到其最优节点)&

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值