使用这个算法我可以实现英雄联盟里英雄的走位|Java 开发实战

本文介绍了A*算法在Java开发中的应用,特别是在模拟英雄联盟英雄走位的情境下。文章详细阐述了A*算法的基本概念、三基值计算、G值和H值的计算方式,以及寻路解析。通过实例展示了如何在地图上寻找最短路径,并分析了算法的效率和不足之处。

image.png

A算法,A(A-Star)算法是一种静态路网中求解最短路径最有效的直接搜索方法,也是解决许多搜索问题的有效算法。算法中的距离估算值与实际值越接近,最终搜索速度越快。

基本概念

  • 首先在大学我们遇到最多的算法Dijkstra、Floyd、广度搜索、深度搜索。关于这些算法我们以后再慢慢的研究,今天的重点在A算法上。A算法是一种启发式算法。与上述几种算法不同的是A*算法在考虑起始节点的同时还会考虑到目标节点的代价。
  • 在A*算法中我们给每个节点都定义一些属性。最基本的就是下文提到的三基数-这里的三基数是我自己定义的一个名词。什么叫启发式就是在探索路径的时候既要选择里起始点最近也要考虑到里目标节点的消费问题。

三基值

  • 上面的一些概念可能会使你很模糊,这里我们直接看定义。

F=G+H : 表示一个节点的总消费值;换句话说就是离起始节点和目标节点距离的总和 G : 表示该从其实节点到该节点的消费值; H : 表示从该节点到目标节点的消费值;(这里注意一下,这里的消费值其实是一个预估值,因为我们无法判断到目标节点的具体路径,这个H值得获取本文会提供三种方法,其中使用最广泛的是曼哈顿距离)

image.png

图1

三基值计算

常规约定

  • 在方格地图中我们约定横向或者纵向单位消费为10
  • 在方格地图中斜向单位消费为14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值