没有采用二叉堆算法优化, 学习了几天终于搞除了一个demo, 这个列子如果点击按钮生成的方块大小不正确,可以先设置下预设调成相应的大小

只能上下左右走

 

using UnityEngine;
using System.Collections;
using System.Collections.Generic;
using System; public class AStar
{ public static PriorityQueue closedList;
public static PriorityQueue openList; public static List<Node> FindPath(Node start, Node goal)
{
closedList = new PriorityQueue();
openList = new PriorityQueue(); //初始化OpenList
openList.Push(start); //把开始节点放入OpenList中 start.F = 0;
start.G = 0;
start.H = NodeCost(start, goal); start.SetH(start.H);
start.SetF(start.F);
start.SetG(start.G); Node node = null;
List<Node> neighbours = null;
Node neighbourNode = null;
DateTime now = System.DateTime.Now; while (openList.Length != 0)
{
node = openList.First(); //如果是终点,就返回一个列表list过去
if (node.x == goal.x && node.y == goal.y)
{
Debug.Log("算法所消耗的时间: " + (System.DateTime.Now - now).TotalSeconds);
return CalculatePath(node);
} neighbours = new List<Node>();
GridManager.Instance.GetNeighbours(node, neighbours); //获取周围的格子加入列表中 //遍历周围的方块
for (int i = 0; i < neighbours.Count; i++)
{
neighbourNode = neighbours[i]; float newCost = node.G + TraverseCost(node,neighbourNode); //相邻的方块如果以前的G值小于 这次计算的G值就忽略该格子
if ((closedList.Contains(neighbourNode) || openList.Contains(neighbourNode)) && (neighbourNode.G <= newCost))
{
continue; }else{
neighbourNode.G = newCost;
neighbourNode.parent = node;
neighbourNode.H = NodeCost(neighbourNode, goal); //这个格子离终点的估算
neighbourNode.F = neighbourNode.G + neighbourNode.H; //显示H F G的值
neighbourNode.SetH(neighbourNode.H);
neighbourNode.SetF(neighbourNode.F);
neighbourNode.SetG(neighbourNode.G); //如果方块不在开启列表中,就添加到开启列表中
if (!openList.Contains(neighbourNode))
{
openList.Push(neighbourNode);
}
}
} //把寻找的节点放入关闭列表中
closedList.Push(node);
openList.Remove(node);
node.closeed = true;
} Debug.Log("算法所消耗的时间: " + (System.DateTime.Now - now).TotalMilliseconds); if (node.x != goal.x && node.y != goal.y)
{
Debug.LogError("没有找到路径");
return null;
} Debug.Log("找到路径了");
return CalculatePath(node);
} /// <summary>
/// 获取两个节点的距离(不计算障碍物)
/// </summary>
/// <param name="a">开始节点</param>
/// <param name="b">结束节点</param>
/// <returns>返回x +y 的距离</returns>
private static int NodeCost(Node a, Node b)
{
int x = (int)Mathf.Abs(b.x - a.x);
int y = (int)Mathf.Abs(b.y - a.y);
return x + y;
} /// <summary>
/// 获取最终路径
/// </summary>
/// <param name="node"></param>
/// <returns></returns>
private static List<Node> CalculatePath(Node node)
{
List<Node> list = new List<Node>(); while (node != null)
{
list.Add(node);
node = node.parent;
}
list.Reverse();
return list;
} public static float TraverseCost(Node a,Node b)
{
if (b.xiejia)
{
b.xiejia = false;
return a.G + 1.4f;
}
else
{
return a.G + 1.0f;
}
} }

 

下载地址: http://yunpan.cn/ccS42whwzQ3Sy  访问密码 97d9

A星算法的更多相关文章

  1. POJ 2449 Remmarguts' Date (SPFA + A星算法) - from lanshui_Yang

    题目大意:给你一个有向图,并给你三个数s.t 和 k ,让你求从点 s 到 点 t 的第 k 短的路径.如果第 k 短路不存在,则输出“-1” ,否则,输出第 k 短路的长度. 解题思路:这道题是一道 ...

  2. 算法起步之A星算法

    原文:算法起步之A星算法 用途: 寻找最短路径,优于bfs跟dfs 描述: 基本描述是,在深度优先搜索的基础上,增加了一个启发式算法,在选择节点的过程中,不是盲目选择,而是有目的的选的,F=G+H,f ...

  3. Cocos2d-x 3.1.1 学习日志16--A星算法(A*搜索算法)学问

    A *搜索算法称为A星算法.这是一个在图形平面,路径.求出最低通过成本的算法. 经常使用于游戏中的NPC的移动计算,或线上游戏的BOT的移动计算上. 首先:1.在Map地图中任取2个点,開始点和结束点 ...

  4. A*搜寻算法(A星算法)

    A*搜寻算法[编辑] 维基百科,自由的百科全书 本条目需要补充更多来源.(2015年6月30日) 请协助添加多方面可靠来源以改善这篇条目,无法查证的内容可能会被提出异议而移除. A*搜索算法,俗称A星 ...

  5. Java开源-astar:A 星算法

    astar A星算法Java实现 一.适用场景 在一张地图中,绘制从起点移动到终点的最优路径,地图中会有障碍物,必须绕开障碍物. 二.算法思路 1. 回溯法得到路径 (如果有路径)采用“结点与结点的父 ...

  6. A星算法(Java实现)

    一.适用场景 在一张地图中.绘制从起点移动到终点的最优路径,地图中会有障碍物.必须绕开障碍物. 二.算法思路 1. 回溯法得到路径 (假设有路径)採用"结点与结点的父节点"的关系从 ...

  7. JAVA根据A星算法规划起点到终点二维坐标的最短路径

    工具类 AStarUtil.java import java.util.*; import java.util.stream.Collectors; /** * A星算法工具类 */ public c ...

  8. AStar A* A星 算法TypeScript版本

    一 演示效果 二  参考教程 <ActionScript3.0 高级动画教程> + 源码 http://download.csdn.net/download/zhengchengpeng/ ...

  9. 基于HTML5的WebGL呈现A星算法3D可视化

    http://www.hightopo.com/demo/astar/astar.html 最近搞个游戏遇到最短路径的常规游戏问题,一时起兴基于HT for Web写了个A*算法的WebGL 3D呈现 ...

  10. 基于HTML5的WebGL呈现A星算法的3D可视化

    http://www.hightopo.com/demo/astar/astar.html 最近搞个游戏遇到最短路径的常规游戏问题,一时起兴基于HT for Web写了个A*算法的WebGL 3D呈现 ...

随机推荐

  1. WPF与输入法冲突研究之二:汉字输入法会导致WPF程序的崩溃!

    如果是输入非汉字的数据信息,可以添加一下内容: xmlns:input="clr-namespace:System.Windows.Input;assembly=PresentationCo ...

  2. Android中获取网页表单中的数据实现思路及代码

    在Android中获取网页里表单中的数据具体实现代码如下,感兴趣的各位可以参考过下哈,希望对大家有所帮助 MainActivity如下: 复制代码 代码如下: package cn.testjavas ...

  3. HR系统+人脸识别

    近期一直在写一套HR系统,这套HR系统和人脸识别相结合.全然杜绝取代刷卡的情况产生.系统的灵活性比較强,开发简洁高速. 例如以下是一些功能上的截图 考勤模块仅仅是列举当中一个请假申请的功能做为展示   ...

  4. 在CentOS 7上利用systemctl加入自己定义系统服务

    CentOS 7继承了RHEL 7的新的特性,比如强大的systemctl,而systemctl的使用也使得以往系统服务的/etc/init.d的启动脚本的方式就此改变,也大幅提高了系统服务的执行效率 ...

  5. LG 2.2.1 P350安卓系统刷机,问题总结,希望对需要的朋友有助

    手机误删软件导致短信,键盘等无声音提醒 我的手机前几天被我误删了一个软件,导致电话接不了,别人打电话的时候,老提示我在通话中,但是我可以在通话中看到对方的打电话记录.短信,键盘,USB连接,等等都没有 ...

  6. UVa 10701 - Pre, in and post

    题目:已知树的前根序,中根序遍历转化成后根序遍历. 分析:递归,DS.依据定义递归求解就可以. 前根序:根,左子树,右子树: 中根序:左子树,根,右子树: 每次,找到根.左子树.右子树,然后分别递归左 ...

  7. 字符串匹配之horspool算法(简化的BM算法)

    前面介绍在BF,KMP这些算法的时候老是提到BM这个东西,究竟这什么东西,有啥高深的,这些问题我们如今不去考虑.不知道,认真读前几篇文章的读者有没有发现前面的算法都是从模式串的前面開始匹配的,那我们就 ...

  8. compass模块----Helpers

    Color Stops:在使用CSS3渐变属性生成图片的时候,有时候为了打造更丰富的渐变效果除了声明渐变线上的起始点和终止点的色值,还有声明一些中间点的色值,这些点我们就称之为Color Stops. ...

  9. 使用css3属性,大部分浏览器要识别前缀

    例如以下代码的解析 -ms-transform:rotate(7deg); -moz-transform:rotate(7deg); -webkit-transform:rotate(7deg); - ...

  10. .net 开发定时执行的windows服务

    环境:win7+vs2010+Oracle11g+office2010(64位操作系统) 需求:开发定时执行的windows服务从数据库中查询数据下载到指定地址Excel中 一.添加新建项目——win ...