`
metaphy
  • 浏览: 344090 次
  • 性别: Icon_minigender_1
  • 来自: 大西洋底
社区版块
存档分类
最新评论

A*寻路例子

阅读更多
如图,绿方块是起点,红方块终点;蓝方块是水(障碍物)。想像在图的周围加上边界,建立坐标系,x和y分别从1开始,则x取值[1,9],y取值[1,7],起点坐标(3,4),终点坐标(7,4);为简单起见,将坐标以一个整数标记:100 * y + x.


路径搜寻过程中,有一点与参考文章不同的是,障碍物的角被认为是可穿过的,只要穿过之后的坐标不是障碍物或边界。

参阅:http://www.cppblog.com/christanxw/archive/2006/04/07/5126.html
英文原文:http://www.gamedev.net/reference/articles/article2003.asp
/**
 * Author by metaphy
 * Date Feb 20, 2008
 */
package astar;

import java.util.ArrayList;

public class Coordinate {
	private int x;
	private int y;
	private int value;
	private Coordinate parent;
	
	public Coordinate(){}
	public Coordinate(int x, int y) {
		this.x = x;
		this.y = y;
		this.value = 100 * y + x;
	}
	public Coordinate(int value) {
		this.x = value % 100;
		this.y = value / 100;
		this.value = value;
	}
	
	public int getX() {
		return x;
	}
	public int getY() {
		return y;
	}
	public int getValue() {
		return value;
	}
	
	public Coordinate getParent() {
		return parent;
	}
	public void setParent(Coordinate parent) {
		this.parent = parent;
	}
	/**
	 * Whether or not it's border
	 * @return
	 */
	public boolean isBorder(){
		return x == 1 || x == 9 || y ==1 || y== 7 ;
	}
	/**
	 * Whether or not it's barrier
	 * @return
	 */
	public boolean isWater(){
		return value == 305
			|| value == 306
			|| value == 405
			|| value == 504
			|| value == 505
		;
	}
	/**
	 * @param xx
	 * @param yy
	 * @return
	 */
	public boolean valid(int xx, int yy){
		return xx >=1 && xx<=9 && yy >=1 && yy<=7;
	}
	
	/**
	 * Get valid adjacent coordinate list
	 * @return
	 */
	public ArrayList<Coordinate> getValidAdjacent(){
		ArrayList<Coordinate> list = new ArrayList<Coordinate>();
		for (int t = -1; t<= 1; t ++){
			for (int p = -1; p<= 1; p++){
				if (valid(x + t,y + p)){
					Coordinate c = new Coordinate (x+t, y+p);
					if (!c.isBorder() && !c.isWater()){
						list.add(c);
					}
				}
			}
		}
		return list;
	}
	/**
	 * The G function 
	 * @param c
	 * @return
	 */
	public int getCostG(){
		if (parent != null){
			if (Math.abs(parent.getX () -x)==1 && Math.abs(parent.getY() - y )==1){
				return 14;
			}else {
				return 10;
			}
		}else {
			return 0 ;
		}
	}
	public int getCostG(Coordinate c){
		if (Math.abs(c.getX () -x)==1 && Math.abs(c.getY() - y )==1){
			return 14;
		}else if (c.getX() == x && Math.abs(c.getY()-y) == 1|| c.getY() ==y && Math.abs(c.getX() -x) ==1){
			return 10;
		}else {
			return Integer.MAX_VALUE;
		}
	}
	/**
	 * The H function 
	 * @param c
	 * @return
	 */
	public int getDistanceH(Coordinate c){
		return (Math.abs(c.getX() - x) + Math.abs(c.getY() - y)) * 10;
	}
	/**
	 * The F function
	 * @param c
	 * @return
	 */
	public int getF(Coordinate c){
		return getCostG() + getDistanceH(c);
	}
}	

/**
 * Author by metaphy
 * Date Feb 20, 2008
 */
package astar;

import java.util.ArrayList;

public class AStarSample {
	private ArrayList<Coordinate> openList = new ArrayList<Coordinate>();
	private ArrayList<Coordinate> closeList = new ArrayList<Coordinate>();
	private Coordinate start = new Coordinate(403);
	private Coordinate end = new Coordinate(407);
	/**
	 * Try to find the path
	 * @return
	 */
	public boolean pathFinding(){
		Coordinate current = null;
		openList.add(start);
		do{
			current = lookForMinF();
			openList.remove(current);
			closeList.add(current);
			ArrayList<Coordinate> list = current.getValidAdjacent();
			for (Coordinate adjacent:list){
				if (!inClosedList(adjacent)){
					if (!inOpenedList(adjacent)){
						adjacent.setParent(current);
						openList.add(adjacent);
					}else{
						int g0 = current.getParent().getCostG(adjacent);
						int g1 = current.getCostG() + current.getCostG(adjacent);
						if (g1 < g0){
							adjacent.setParent(current);
						}
					}
				}
			}
		} while(!findTarget() && openList.size()>0);
		end.setParent(current);
		
		if (findTarget()){
			Coordinate tmp = end;
			while (tmp.getValue() != start.getValue()){
				System.out.println(tmp.getValue());
				tmp = tmp.getParent();
			}
			System.out.println(start.getValue());
			return true;
		}else{
			System.out.println("Can't find the path.");
			return false;
		}
	}
	/**
	 * Look for the min F value coordinate from open list 
	 * @return
	 */
	private Coordinate lookForMinF(){
		Coordinate c = openList.get(0);
		for (Coordinate tmp :openList){
			if (tmp.getF(end) < c.getF(end)){
				c = tmp ;
			}
		}
		return c;
	}
	/**
	 * Find the target or not
	 * @return
	 */
	private boolean findTarget(){
		for (Coordinate open: openList){
			if (open.getValue() == end.getValue())
				return true;
		}
		return false;
	}
	private boolean inClosedList(Coordinate c){
		for (Coordinate close: closeList){
			if (close.getValue() == c.getValue())
				return true;
		}
		return false;
	}
	private boolean inOpenedList (Coordinate c){
		for (Coordinate open: openList){
			if (open.getValue() == c.getValue())
				return true;
		}
		return false;
	}
	public static void main(String[] args) {
		new AStarSample().pathFinding();
	}
}
分享到:
评论
7 楼 hxz_qlh 2011-08-07  
呵呵 楼主 这个方法写错了啊:
Get valid adjacent coordinate list
{

}
判断是否将新节点加入list这一步应该是:
if (!c.isWater())
{
    list.add(c);
}
否则,边界点都遗漏了哈。。。。
更正此方法如下:
  /**
     * Get valid adjacent coordinate list
     * 
     * @return
     */
    public ArrayList<Coordinate> getValidAdjacent()
    {
        ArrayList<Coordinate> list = new ArrayList<Coordinate>();
        for (int t = -1; t <= 1; t++)
        {
            for (int p = -1 ; p <= 1; p++)
            {
                if (valid(x + t, y + p))
                {
                    Coordinate c = new Coordinate(x + t, y + p);
                    if (!c.isWater())
                    {
                        list.add(c);
                    }
                }
            }
        }
        return list;
    }
6 楼 hxz_qlh 2011-08-03  
要是楼主能把这个寻路的思想也在这里讲解下酒更好了。。。。。
5 楼 hxz_qlh 2011-08-03  
shellkk 写道
给楼主一个建议,把具体问题和搜索算法分离开来,为目标问题定义一个接口,这样算法就可以重用了。

4 楼 bcccs 2008-03-10  
lick 写道
楼主还真抬举他

建议回去研究一下楼主和楼上2个词的区别
3 楼 shellkk 2008-03-10  
给楼主一个建议,把具体问题和搜索算法分离开来,为目标问题定义一个接口,这样算法就可以重用了。
2 楼 lick 2008-03-10  
楼主还真抬举他
1 楼 linwenbin 2008-02-23  
无语,这种东东 好像是 有3-4年以上的人才能完整写出来的。

相关推荐

    a*寻路demo

    a*寻路例子

    A*寻路的AS实现例子

    标题 "A*寻路的AS实现例子" 指的是使用ActionScript(一种基于ECMAScript的脚本语言,常用于Adobe Flash开发)实现A*(A-star)寻路算法的一个示例项目。A*算法是一种广泛应用在路径规划中的启发式搜索算法,尤其在...

    简单的A*寻路算法例子

    A*(发音为“A-star”)寻路算法是一种在图形中寻找从起点到终点最短路径的高效算法,尤其适用于游戏开发、地图导航等领域。它结合了Dijkstra算法的全局最优性和启发式搜索的效率,通过引入估计代价来快速找到最佳...

    Python3 A*寻路算法实现方式

    A* (A-star) 寻路算法是一种广泛应用在游戏开发、地图导航、路径规划等领域的高效搜索算法。它结合了Dijkstra算法的最短路径特性与优先队列的效率,通过引入启发式函数来指导搜索过程,使得路径查找更加智能且节省...

    二叉堆实现A*寻路算法c语言实例

    二叉堆实现A*寻路算法是计算机科学中一种经典的路径搜索方法,它结合了Dijkstra算法和优先级队列的特性,以高效的方式寻找从起点到目标点的最短路径。在这个C语言实例中,我们看到AStar.c、AStar.h、main.c和...

    Uniry3D A*项目例子

    Unity3D A*项目例子 主要介绍在unity3d 平台上 各种不同地形A*寻路

    Unity 2D A星寻路算法实现(2D与2.5D)

    这个是我个人自己写的Unity 2D环境中的寻路, 分别有两个文件夹,AIPath 是正面2D 环境,45AIPath 是斜45度角(2.5D)环境,本资源包含了一份PDF繁体中文教学文件,而在最后我也提出了一些问题,望高手解答。...

    A*算法的具体思想(我见过的写的最好的一份)

    1. A*算法的寻路原理 A*算法将搜索区域简化为二维数组,每个元素代表一个网格方块。这个二维数组可以帮助我们简化搜索过程。在A*算法中,路径被描述为从起点到终点所经过的方块的集合。每个方块称为一个节点,节点...

    a 星算法原理 新手入门

    在本文中,我们将详细讲解A*寻路算法的原理,并提供了一个例子程序包的下载链接,可以帮助读者更好地理解算法的实现。 一、搜索区域简化 在A*寻路算法中,我们首先需要将搜索区域简化为一个二维数组。我们假设某个...

    android寻路小例子

    这个"android寻路小例子"就是一个很好的起点,它涵盖了基础的寻路算法实现,并且提供了源代码供学习和参考。下面我们将深入探讨这个主题。 首先,我们需要理解寻路算法的基本概念。寻路算法是用来解决在图(graph)...

    基于C4的A*例子,不错的

    在这个例子中,A*算法被集成到C4环境中,可能用于实现角色的自动寻路功能。 Navmesh(导航网格)是A*算法常用的一种数据结构,它将复杂的空间划分为一系列可行走的多边形,每个多边形代表一个导航单元。角色可以只...

    A星算法,游戏自动寻路源码例子-易语言

    A星(A*)算法是一种在图形搜索中用于找到两点之间最短路径的高效算法,尤其在游戏开发中,用于实现角色或NPC的自动寻路功能。易语言是一种中文编程语言,它使得编程过程更加直观易懂,尤其适合初学者。在本案例中,...

    unity A*算法实例

    Unity中的A*算法实例主要涉及游戏开发中的路径搜索和寻路技术。A*(A-star)算法是一种在图形网络中寻找最优路径的搜索算法,它结合了Dijkstra算法的最短路径特性与最佳优先搜索算法的效率。在这个实例中,我们将在...

    CCSimplePathFinding:使用A *寻路算法为简单世界寻找简单路径。 对于cocos2dx v3

    CCSimplePathFinding 使用A *寻路算法为简单世界寻找简单路径。 对于cocos2dx v3文档:感谢Ray Wenderlich:如何使用: 1.创建一个二维矩阵世界: 例子:```c ++ std :: vector&gt;矩阵std :: vector row1 = {1,1,1,1,1...

    A星寻路算法

    在这个例子中,A星算法被应用到一个45度角的地图上,用于游戏中的角色导航。 A*算法的核心在于它结合了Dijkstra算法的最短路径搜索和启发式信息来优化搜索效率。Dijkstra算法虽然能保证找到最短路径,但效率较低,...

    a*算法(a星)————例子哦

    在"A_寻路(AS3)"的示例中,可能包含了AS3代码实现的详细步骤,包括节点表示、启发式函数的定义、开放列表和关闭列表的管理以及路径的查找和返回。通过阅读和理解这段代码,你可以深入学习如何在实际项目中应用A*...

    pythonA*算法(A-star algorithm),寻路算法

    A*算法(A-star algorithm)是一种启发式搜索算法,用于在图形路径...在这个例子中,我们使用了曼哈顿距离作为启发式函数,但这可能不适用于所有情况。在实际应用中,选择合适的启发式函数对于A*算法的性能至关重要。

    AS3 A星算法以及实例

    描述中提到这是一个包含源文件和源代码的实际例子,这为我们提供了学习和理解A星算法在AS3中的具体应用提供了宝贵的资源。通过查看和运行这些源代码,我们可以深入理解算法的内部工作原理,以及如何在实际项目中有效...

    A*算法实现最短路径搜索

    在学习了著名的A星算法之后,我便有了想法要把它实现出来。这是对A*算法的一整套详细实现,固定地图障碍物,自选起点和终点,实现最短最优路径搜索,可用在游戏自动寻路上(要用vs编译)

    A*算法入门

    在许多实际应用中,比如电子游戏中角色的自动寻路、地图应用中的驾车路线规划以及机器人技术中的自主导航等场景,都需要高效地找到两点间的最短路径或最优路径。A*算法通过结合启发式搜索策略,能够在复杂的环境中...

Global site tag (gtag.js) - Google Analytics