博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
a*寻路分析
阅读量:5301 次
发布时间:2019-06-14

本文共 674 字,大约阅读时间需要 2 分钟。

http://dev.gameres.com/Program/Abstract/Arithmetic/A%20Pathfinding%20for%20Beginners.htm

 

定义:

绿色节点为A

红色节点为B

A右边为C

Dst:使用两点距离计算公式

表Op :储存节点用 (开放列表)

表Cl :储存节点用 (开放列表)

节点的上级节点 名为 FN

GL : 节点属性 用于储存与A的距离

 

下述计算过程定义为 过程1

Strat

  计算 C 与 B 的距离( Dst )  结果为 H

  计算 C 与 A 的距离( Dst )  结果为 G

  F=H+G

      将 C 加入 表Op

      C 的 FN = A

      C 的 GL = FN 的 GL + C与A的距离

End

 

把 A 周围的节点都使用 过程1 计算一遍(不包含 表Cl 里的节点,及不可通过节点),选择 F 较小的做为新节点(定义:新节点=N)

将 A 加入 表Cl,N 加入 表Cl,从 表Op 移除 N

 

将 N 当成 A 以 过程1 计算 直至找到 B。

 

对于 表Op 里的节点的使用:

表Op 里的节点有时会包含 N 周围的节点,包含时这个节点定义为 M

计算 M 的 FN  离 A 近 还是将 N 当为 M 的 FN 离 A 近   (主要使用了 GL)

 

结果路线为 B 的 FN 的 FN 直到A

 

http://files.cnblogs.com/mattins/aStar.zip

转载于:https://www.cnblogs.com/mattins/p/3504679.html

你可能感兴趣的文章
Linq 学习(1) Group & Join--网摘
查看>>
asp.net 调用前台JS调用后台,后台掉前台JS
查看>>
Attribute(特性)与AOP
查看>>
苹果手表:大方向和谷歌一样,硬件分道扬镳
查看>>
Competing Consumers Pattern (竞争消费者模式)
查看>>
Android面试收集录15 Android Bitmap压缩策略
查看>>
PHP魔术方法之__call与__callStatic方法
查看>>
ubuntu 安装后的配置
查看>>
web前端之路,js的一些好书(摘自聂微东 )
查看>>
【模板】对拍程序
查看>>
【转】redo与undo
查看>>
解决升级系统导致的 curl: (48) An unknown option was passed in to libcurl
查看>>
Java Session 介绍;
查看>>
spoj TBATTLE 质因数分解+二分
查看>>
Django 模型层
查看>>
dedecms讲解-arc.listview.class.php分析,列表页展示
查看>>
Extjs6 经典版 combo下拉框数据的使用及动态传参
查看>>
【NodeJS】http-server.cmd
查看>>
研磨JavaScript系列(五):奇妙的对象
查看>>
面试题2
查看>>