码迷,mamicode.com
首页 > 编程语言 > 详细

A*寻路算法入门(五)

时间:2015-11-22 08:55:13      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:

大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处.
如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;)


免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流之用,请勿进行商业用途。同时,转载时不要移除本申明。如产生任何纠纷,均与本博客所有人、发表该翻译稿之人无任何关系。谢谢合作!

关于A*算法

现在你该知道如何计算每一个方块的分值了(我们将称之为F,它等于G+H),让我们看看A*算法是如何工作的.

这只猫咪将用以下重复的步骤来找到最短路径:

  1. 从开发列表中取得分值最小的方块,我们称之为方块S.
  2. 将方块S从开发列表中删除,并且添加到闭合列表中.
  3. 对于方块S的每一个可到达的邻居方块T:
    A.如果T在闭合列表中:忽略它.
    B.如果T不在开发列表中:把它添加进来并计算它的分值.
    C.如果T已经存在于开放列表中:检查其F值是否比我们使用当前生成的路径要小.如果是,更新它的分值和它父方块.

如果你有点混乱也不用担心 — 我们将用一个例子一步步的像你展示它是如何工作的! :]

猫咪的路径

让我们通过一个例子看看这只懒猫咪是如何找到骨头的.

在下面的图示中,我已经将对应的值列出来了(F = G + H):

  • F(方块的分值):左上角
  • G(从A点到方块的花费):左下角
  • H(从方块到B点的估计花费):右下角

同样,箭头显示出到达该方块的移动方向(指向其父方块.猫猪注).

最终,对于每一步来说,红色方块指示闭合列表,绿色方块指示开发列表.

OK,让我们开始吧!

步骤1

在第一步中,这只猫咪确定其起始位置(点A)的可到的达邻居方块,计算他们的F分值,然后将它们添加到开放列表中:

技术分享

你可以看到每一个方块中列出了H值(2个为6,一个为4).我建议根据”街区距离”算法自己计算一下,确保你理解这部分是如何工作的.

同样要注意的是F值(左上角)正好是G+H的和(左下角和右下角).

步骤2

接下来,猫咪选择最小分值的方块,将其添加到闭合列表中去,并且获得他的邻居方块.

技术分享

所以你将看到最小分值方块的F值为4,我们试图将所有它的邻居瓦块添加到开发列表中(并且计算它们的分值),除非它不能被添加(因为它已经在闭合列表中了)或者它是不可到达的(比如墙壁).

注意这里有2个新的瓦块被添加到开放列表中,G值被加1,因为从起始位置到它们有2个瓦块的距离.你可能想去用”街区距离”算法计算一下以确保你懂了了这些新添加瓦块的H值是如何计算的.

A*寻路算法入门(五)

标签:

原文地址:http://blog.csdn.net/mydo/article/details/49975365

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!