亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? astar.cpp

?? A*算法
?? CPP
字號:
// AStar.cpp: implementation of the CAStar class.
//
//////////////////////////////////////////////////////////////////////

#include "AStar.h"
#include <math.h>
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////


CAStar::CAStar()
{
	pASNode=NULL;
}

int CAStar::GetNodeIndex(int pathIndex)
{
	return PathList[PathList.size()-pathIndex-1];
}

bool CAStar::FindPath(int FromIndex,int ToIndex)
{
	OpenList.clear();
	PathList.clear();
	int i=0;
	//打開起始點
	pASNode[FromIndex].bIsOpen=true;
	pASNode[FromIndex].G=0;
	OpenList.push_back(FromIndex);
	//計算所有的H值
	for(i=0;i<NodeCount;i++)
	{
		pASNode[i].H=sqrt(pow(pASNode[i].x-pASNode[ToIndex].x,2)+
					      pow(pASNode[i].y-pASNode[ToIndex].y,2));
	}
	while(1)
	{
		bool bFoundPath=false;
		int NotClosedCount=0;
		for(i=0;i<OpenList.size();i++)
		{
			//遍歷所有打開并且沒有關閉的點,
			if(!pASNode[OpenList[i]].bIsClose)
			{
				//如果打開的點是目標點,則退出循環,到達
				if(OpenList[i]==ToIndex)
					bFoundPath=true;//找到目標點
				NotClosedCount++;
			}
		}

		//如果所有打開的點都已被關閉,則退出,不可達
		if(NotClosedCount==0)
			return false;
		//從打開列表中找到一個F值最小的點
		int MinFIndex=-1;
		int MinF=99999999;
		for(i=0;i<OpenList.size();i++)
		{
			//遍歷所有打開并且沒有關閉的點,尋找最小的F值
			int tempI=OpenList[i];
			if(!pASNode[tempI].bIsClose)
			{
				int tempF=pASNode[tempI].G+pASNode[ToIndex].H;
				if(tempF<MinF)
				{
					MinF=tempF;
					MinFIndex=tempI;
				}
			}
		}
		//從打開列表中找到一個F值最小的點,把他的鄰居全打開,把自己關閉,設置parent
		//并查看鄰居,看自己做鄰居的父結點是否能夠獲得更小的G值		
		for(int j=0;j<pASNode[MinFIndex].NeighborCount;j++)
		{
			SASNode *pTempChild=&pASNode[pASNode[MinFIndex].Neighbor[j]];
			if(pTempChild->bIsOpen)//如果是打開的鄰居,看自己是否可以做它的父結點
			{
				if(pTempChild->G>pASNode[MinFIndex].G+pASNode[MinFIndex].NeighborDistance[j])
				{
					pTempChild->G=pASNode[MinFIndex].G+pASNode[MinFIndex].NeighborDistance[j];
					pTempChild->ParentIndex=MinFIndex;
				}
			}
			else
			{
				pTempChild->bIsOpen=true;
				OpenList.push_back(pASNode[MinFIndex].Neighbor[j]);//加入打開列表
				pTempChild->ParentIndex=MinFIndex;
				pTempChild->G=pASNode[MinFIndex].G+pASNode[MinFIndex].NeighborDistance[j];
			}
		}
		pASNode[MinFIndex].bIsClose=true;
		if(bFoundPath)
			break;
		//繼續循環
	}
	//如果運行到此處,則說明已經到達了目標,則從目標逆推得到路徑
	int tempIndex=ToIndex;
	PathList.push_back(tempIndex);
	while(tempIndex!=FromIndex)
	{
		tempIndex=pASNode[tempIndex].ParentIndex;
		PathList.push_back(tempIndex);
	}
	//路徑已經存儲完畢
	PathPointCount=PathList.size();
	return true;
}

int CAStar::GetNodeCount()
{
	return PathPointCount;
}

void CAStar::InitNodeByWayPoint(CWayPoint *pWayPoint)
{
	if(pASNode)
	{
		delete[] pASNode;
		pASNode=NULL;
	}
	NodeCount=pWayPoint->GetNodeCount();
	pASNode=new SASNode[NodeCount];
	for(int i=0;i<NodeCount;i++)
	{
		SWPNode* wpNode=pWayPoint->GetWPNode(i);
		pASNode[i].x=wpNode->x;
		pASNode[i].y=wpNode->y;
		pASNode[i].bIsClose=false;
		pASNode[i].bIsOpen=false;
		pASNode[i].F=0;
		pASNode[i].G=0;
		pASNode[i].ParentIndex=-1;
		pASNode[i].NeighborCount=0;
		for(int j=0;j<wpNode->NeighborCount;j++)
		{
			pASNode[i].NeighborCount=wpNode->NeighborCount;
			pASNode[i].Neighbor[j]=pWayPoint->GetIndexFromID(wpNode->Neighbor[j]);
			pASNode[i].NeighborDistance[j]=wpNode->NeighborDistance[j];
		}
	}
}

CAStar::~CAStar()
{
	delete[] pASNode;
	pASNode=NULL;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美腿丝袜一区二区三区| 亚洲在线观看免费| 欧美成人三级电影在线| 欧美日韩专区在线| 欧美日韩国产高清一区二区三区 | 成人动漫av在线| 在线观看免费亚洲| 成人免费高清视频在线观看| 另类综合日韩欧美亚洲| 亚洲精品久久久蜜桃| 亚洲福利视频一区| 欧美中文字幕一区二区三区 | 亚洲区小说区图片区qvod| 一区二区三区欧美在线观看| 亚洲综合色网站| 日本视频一区二区三区| 高潮精品一区videoshd| 欧美日韩中文字幕精品| 欧美精品一区二区蜜臀亚洲| 国产精品免费视频观看| 日本sm残虐另类| 免费成人性网站| 欧美在线看片a免费观看| 26uuu欧美| 国产成人av一区二区三区在线观看| 色婷婷久久久综合中文字幕| 欧美色综合网站| 亚洲视频在线一区观看| 久久99蜜桃精品| 欧美体内she精高潮| 亚洲私人影院在线观看| 不卡的av电影在线观看| 欧美一区二区三区免费视频| 亚洲国产精品久久不卡毛片 | 成人av资源站| 国产欧美日韩不卡| 懂色av一区二区在线播放| 欧美精品一区男女天堂| 日本中文字幕一区二区视频 | 综合亚洲深深色噜噜狠狠网站| 久久精品久久综合| 精品粉嫩aⅴ一区二区三区四区| 亚洲图片欧美色图| 色狠狠桃花综合| 午夜视频在线观看一区| 欧美系列日韩一区| 久久成人av少妇免费| 久久婷婷国产综合国色天香| 成人免费视频一区| 亚洲婷婷综合色高清在线| 日本韩国精品在线| 日韩av电影天堂| 久久精品人人做人人综合| 99视频有精品| 日韩电影一区二区三区| 欧美高清hd18日本| 国产精品亚洲一区二区三区在线 | 国产.欧美.日韩| 久久久亚洲精品一区二区三区| 国产一区二区剧情av在线| 国产精品美女久久久久久2018| 欧美喷潮久久久xxxxx| 日韩欧美卡一卡二| 精品一区二区免费看| 日本视频一区二区三区| 欧美精品一区男女天堂| 99re视频这里只有精品| 亚洲国产乱码最新视频| 精品蜜桃在线看| 色视频欧美一区二区三区| 欧美激情一区在线观看| 91激情在线视频| 91美女片黄在线观看| 亚洲精品乱码久久久久久久久| 日韩女优电影在线观看| 51久久夜色精品国产麻豆| 在线一区二区三区| 在线一区二区观看| 91美女蜜桃在线| 91国产精品成人| 欧洲激情一区二区| 欧美日韩一二三区| 欧美日韩在线精品一区二区三区激情| 欧洲一区二区三区免费视频| 91久久人澡人人添人人爽欧美| 日本丶国产丶欧美色综合| 91激情在线视频| 8x8x8国产精品| 91精品综合久久久久久| 欧美成人官网二区| 久久久三级国产网站| 国产精品青草久久| 中文字幕欧美区| 一区二区三区中文字幕电影 | 午夜精品一区二区三区三上悠亚| 一区二区三区影院| 偷拍自拍另类欧美| 蜜桃精品在线观看| 国产99久久精品| 91在线看国产| 精品视频在线免费看| 欧美一区二区福利在线| 国产欧美日韩三级| 亚洲韩国精品一区| 激情五月婷婷综合| av在线不卡观看免费观看| 精品视频1区2区3区| 久久综合一区二区| 亚洲激情五月婷婷| 青娱乐精品视频| 福利视频网站一区二区三区| 在线免费观看日本欧美| 日韩欧美亚洲一区二区| 中文字幕+乱码+中文字幕一区| 国产精品主播直播| 成人激情动漫在线观看| 久久午夜免费电影| 亚洲综合久久av| 国产成人av一区二区三区在线观看| 成人综合日日夜夜| 欧美日韩成人一区| 中文字幕精品一区二区三区精品| 亚洲国产精品一区二区久久| 天天影视涩香欲综合网| 国产电影一区在线| 欧美疯狂做受xxxx富婆| 久久久久亚洲综合| 欧美网站大全在线观看| 久久久久亚洲蜜桃| 三级一区在线视频先锋| 97国产一区二区| 久久久影视传媒| 亚洲成人av电影在线| av男人天堂一区| 久久亚洲精华国产精华液 | 欧美视频一区二| 国产性做久久久久久| 日韩高清欧美激情| 欧美亚洲一区二区在线观看| 国产日韩成人精品| 免费成人在线观看视频| 色88888久久久久久影院野外| 国产校园另类小说区| 日本成人在线网站| 欧美三区在线观看| 日韩毛片一二三区| 本田岬高潮一区二区三区| 久久久久国产免费免费| 激情文学综合插| 欧美成人性战久久| 美女久久久精品| 日韩欧美一区中文| 免费在线视频一区| 6080日韩午夜伦伦午夜伦| 一区二区在线观看av| 色婷婷av一区| 亚洲欧美国产三级| 91麻豆福利精品推荐| 国产精品传媒视频| 91影视在线播放| 亚洲欧美综合网| 99久久久国产精品免费蜜臀| 国产精品美女久久久久aⅴ| 成人激情午夜影院| 欧美极品少妇xxxxⅹ高跟鞋| 懂色一区二区三区免费观看| 久久久久久久久97黄色工厂| 国产一区福利在线| 国产亚洲欧美在线| 国产成人一区在线| 国产精品毛片a∨一区二区三区| 国产成人夜色高潮福利影视| 国产精品三级在线观看| av激情综合网| 亚洲激情六月丁香| 欧美性受极品xxxx喷水| www.欧美日韩| 国产一区二区视频在线| 91欧美一区二区| 成人一区在线看| 日韩国产欧美三级| 亚洲一线二线三线久久久| 久久精品亚洲麻豆av一区二区| 日本高清免费不卡视频| 国产成人午夜高潮毛片| 免费欧美在线视频| 亚洲曰韩产成在线| 亚洲精品视频在线| 一色屋精品亚洲香蕉网站| 亚洲视频狠狠干| 国产精品国产三级国产三级人妇| 91视视频在线观看入口直接观看www | 91在线小视频| 亚洲福利电影网| 欧美精品一区二| 91亚洲精品久久久蜜桃| 日本亚洲最大的色成网站www| 久久久九九九九| 欧美午夜一区二区三区| 久久爱www久久做|