A*算法入门

http://www.cppblog.com/mythit/archive/2009/04/19/80492.aspx  收藏一下



在看下面这篇文章之前,先介绍几个理论知识,有助于理解A*算法。


启发式搜索:启发式搜索就是在状态空间中的搜索对每一个搜索的位置进行评估,得到最好的位置,再从这个位置进行搜索直到目标。这样可以省略大量无畏的搜索路径,提到了效率。在启发式搜索中,对位置的估价是十分重要的。采用了不同的估价可以有不同的效果。


估价函数:从当前节点移动到目标节点的预估费用;这个估计就是启发式的。在寻路问题和迷宫问题中,我们通常用曼哈顿(manhattan)估价函数(下文有介绍)预估费用。


A*算法与BFS:可以这样说,BFS是A*算法的一个特例。对于一个BFS算法,从当前节点扩展出来的每一个节点(如果没有被访问过的话)都要放进队列进行进一步扩展。也就是说BFS的估计函数h永远等于0,没有一点启发式的信息,可以认为BFS是“最烂的”A*算法。


选取最小估价:如果学过数据结构的话,应该可以知道,对于每次都要选取最小估价的节点,应该用到最小优先级队列(也叫最小二叉堆)。在C++的STL里有现成的数据结构priority_queue,可以直接使用。当然不要忘了重载自定义节点的比较操作符。


A*算法的特点:A*算法在理论上是时间最优的,但是也有缺点:它的空间增长是指数级别的。


IDA*算法:这种算法被称为迭代加深A*算法,可以有效的解决A*空间增长带来的问题,甚至可以不用到优先级队列。如果要知道详细:google一下。




 
A*寻路初探(转载)


 


作者:Patrick Lester


译者:Panic2005年


 


译者序:很久以前就知道了A*算法,但是从未认真读过相关的文章,也没有看过代码,只是脑子里有个模糊的概念。这次决定从头开始,研究一下这个被人推崇备至的简单方法,作为学习人工智能的开始。


这篇文章非常知名,国内应该有不少人翻译过它,我没有查找,觉得翻译本身也是对自身英文水平的锻炼。经过努力,终于完成了文档,也明白的A*算法的原理。毫无疑问,作者用形象的描述,简洁诙谐的语言由浅入深的讲述了这一神奇的算法,相信每个读过的人都会对此有所认识(如果没有,那就是偶的翻译太差了--b)。


现在是年月日的版本,应原作者要求,对文中的某些算法细节做了修改。


原文链接:http://www.gamedev.net/reference/articles/article2003.asp


原作者文章链接:http://www.policyalmanac.org/games/aStarTutorial.htm


更多 内容请点击这里看原文


理解A*寻路算法具体过程

http://www.cnblogs.com/technology/archive/2011/05/26/2058842.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Cocos A*算法寻路是基于A*算法的一种路径搜索算法,用于在游戏中实现角色的自动寻路功能。A*算法是一种启发式搜索算法,它通过评估节点的启发式值来选择最优路径。在待探索列表里,A*算法会先预测哪个节点的路径可能会最短,并优先对该节点展开。这个预测是基于对未探索路径的假设和预测,假设所有路都能通行的前提下,总路径最短。 与传统的Dijkstra算法相比,A*算法在选择展开节点时有一定的优化思路。A*算法会尽量往可能最短的路径去展开寻找,减少不必要的分支,提高寻路的效率。例如,在图论中,假设找到一个中间节点B后,A*算法会计算经过B点从A到E的最短路径(AB)加上从B到E的路径(BE),并尽量展开这条可能最短的路径。这种优化思路可以应用于RPG游戏中,其中路径长度可以计算为从一个点到另一个点经过的格子数。 总之,Cocos A*算法寻路是基于A*算法的一种路径搜索算法,它通过优先选择可能最短的路径来实现自动寻路功能。这种算法可以在游戏开发中提高寻路效率并提供更好的游戏体验。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [cocos creator 实现 A* 算法](https://blog.csdn.net/weixin_41316824/article/details/86607911)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [cocos creator主程入门教程(十)—— A*寻路](https://blog.csdn.net/houjia159/article/details/108450617)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值