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

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

?? sample.cpp

?? A*算法是
?? CPP
字號:
// sample.cpp : Defines the class behaviors for the application.
//

#include "stdafx.h"
#include "sample.h"
#include "sampleDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif



            // #define NDEBUG
            #include <stdio.h>
            #include <conio.h>
            #include <assert.h>
            #include <stdlib.h>
            #define MAPMAXSIZE 100  //地圖面積最大為 100x100
            #define MAXINT 8192     //定義一個最大整數, 地圖上任意兩點距離不會超過它
            #define STACKSIZE 65536 //保存搜索節點的堆棧大小
            #define tile_num(x,y) ((y)*map_w+(x))  //將 x,y 坐標轉換為地圖上塊的編號
            #define tile_x(n) ((n)%map_w)          //由塊編號得出 x,y 坐標
            #define tile_y(n) ((n)/map_w)
            // 樹結構, 比較特殊, 是從葉節點向根節點反向鏈接
 
/////////////////////////////////////////////////////////////////////////////
// CSampleApp

BEGIN_MESSAGE_MAP(CSampleApp, CWinApp)
	//{{AFX_MSG_MAP(CSampleApp)
		// NOTE - the ClassWizard will add and remove mapping macros here.
		//    DO NOT EDIT what you see in these blocks of generated code!
	//}}AFX_MSG
	ON_COMMAND(ID_HELP, CWinApp::OnHelp)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CSampleApp construction

CSampleApp::CSampleApp()
{
	// TODO: add construction code here,
	// Place all significant initialization in InitInstance
}

/////////////////////////////////////////////////////////////////////////////
// The one and only CSampleApp object

CSampleApp theApp;

/////////////////////////////////////////////////////////////////////////////
// CSampleApp initialization

BOOL CSampleApp::InitInstance()
{
	AfxEnableControlContainer();

	// Standard initialization
	// If you are not using these features and wish to reduce the size
	//  of your final executable, you should remove from the following
	//  the specific initialization routines you do not need.

#ifdef _AFXDLL
	Enable3dControls();			// Call this when using MFC in a shared DLL
#else
	Enable3dControlsStatic();	// Call this when linking to MFC statically
#endif

	CSampleDlg dlg;
	m_pMainWnd = &dlg;
	int nResponse = dlg.DoModal();
	if (nResponse == IDOK)
	{
		// TODO: Place code here to handle when the dialog is
		//  dismissed with OK
	}
	else if (nResponse == IDCANCEL)
	{
		// TODO: Place code here to handle when the dialog is
		//  dismissed with Cancel
	}

	// Since the dialog has been closed, return FALSE so that we exit the
	//  application, rather than start the application's message pump.
	return FALSE;
}
 












LINK queue;               // 保存沒有處理的行走方法的節點
TREE stack[STACKSIZE];    // 保存已經處理過的節點 (搜索完后釋放)
int stacktop;
unsigned char map[MAPMAXSIZE][MAPMAXSIZE];   //地圖數據
int dis_map[MAPMAXSIZE][MAPMAXSIZE];         //保存搜索路徑時,中間目標地最優解
int map_w,map_h;                             //地圖寬和高
int start_x,start_y,end_x,end_y;             //地點,終點坐標
// 初始化隊列


void init_queue()
{
	 queue=(LINK)malloc(sizeof(*queue));
	 queue->node=NULL;
	 queue->f=-1;
	 queue->next=(LINK)malloc(sizeof(*queue));
	 queue->next->f=MAXINT;
	 queue->next->node=NULL;
	 queue->next->next=NULL;
}
// 待處理節點入隊列, 依靠對目的地估價距離插入排序
void enter_queue(TREE node,int f)
{
	 LINK p=queue,father,q;
	 while(f>p->f) {
	   father=p;
	   p=p->next;
	   assert(p);
	   }
	 q=(LINK)malloc(sizeof(*q));
	 assert(queue);
	 q->f=f,q->node=node,q->next=p;
	 father->next=q;
}
// 將離目的地估計最近的方案出隊列
TREE get_from_queue()
{
	 TREE bestchoice=queue->next->node;
	 LINK next=queue->next->next;
	 free(queue->next);
	 queue->next=next;
	 stack[stacktop++]=bestchoice;
	 assert(stacktop<STACKSIZE);
	 return bestchoice;
}
// 釋放棧頂節點
void pop_stack()
{
	 free(stack[--stacktop]);
}
// 釋放申請過的所有節點
void freetree()
{
	 int i;
	 LINK p;
	 for (i=0;i<stacktop;i++)
		free(stack[i]);
	 while (queue) {
	   p=queue;
	   free(p->node);
	   queue=queue->next;
	   free(p);
	   }
}
// 估價函數,估價 x,y 到目的地的距離,估計值必須保證比實際值小
int judge(int x,int y)
{
	 int distance;
	 distance=abs(end_x-x)+abs(end_y-y);
	 return distance;
}
// 嘗試下一步移動到 x,y 可行否
int trytile(int x,int y,TREE father)
{
	 TREE p=father;
	 int h;
	 if (map[y][x]!=' ') return 1; // 如果 (x,y) 處是障礙,失敗
	 while (p) {
	   if (x==tile_x(p->tile) && y==tile_y(p->tile)) return 1; //如果 (x,y) 曾經經過,失敗 

	   p=p->father;
	   }
	 h=father->h+1;
	 if (h>=dis_map[y][x]) return 1; // 如果曾經有更好的方案移動到 (x,y) 失敗
	 dis_map[y][x]=h; // 記錄這次到 (x,y) 的距離為歷史最佳距離
	// 將這步方案記入待處理隊列
	 p=(TREE)malloc(sizeof(*p));
	 p->father=father;
	 p->h=father->h+1;
	 p->tile=tile_num(x,y);
	 enter_queue(p,p->h+judge(x,y));
	 return 0;
}
            // 路徑尋找主函數
void findpath(int *path)
{
	 TREE root;
	 int i,j;
	 stacktop=0;
	 for (i=0;i<map_h;i++)
		 for (j=0;j<map_w;j++)
			 dis_map[i][j]=MAXINT;
	 init_queue();
	 root=(TREE)malloc(sizeof(*root));
	 root->tile=tile_num(start_x,start_y);
	 root->h=0;
	 root->father=NULL;
	 enter_queue(root,judge(start_x,start_y));
	for (;;)
	{
		int x,y,child;
		TREE p;
		root=get_from_queue();
		if (root==NULL) {
		  *path=-1;
		  return;
		}
		x=tile_x(root->tile);
		y=tile_y(root->tile);
		
		if (x==end_x && y==end_y) break; // 達到目的地成功返回
		
		child=trytile(x,y-1,root);  //嘗試向上移動
		child&=trytile(x,y+1,root); //嘗試向下移動
		child&=trytile(x-1,y,root); //嘗試向左移動
		child&=trytile(x+1,y,root); //嘗試向右移動
		
		if (child!=0)
		   pop_stack();  // 如果四個方向均不能移動,釋放這個死節點
    }
// 回溯樹,將求出的最佳路徑保存在 path[] 中
	 for (i=0;root;i++)
	 {
		path[i]=root->tile;
		root=root->father;
	 }
	 path[i]=-1;
	 freetree();
}
void printpath(int *path)
{
 int i;
 for (i=0;path[i]>=0;i++) {
    gotoxy(tile_x(path[i])+1,tile_y(path[i])+1);
    cprintf(\xfe);
    }
}
int readmap()
{
	 FILE *f;
	 int i,j;
	 f=fopen(map.dat,r);

	 assert(f);

	 fscanf(f,%d,%d\n,&map_w,&map_h);
	 for (i=0;i<map_h;i++)
	 fgets(&map[i][0],map_w+1,f);
	 fclose(f);
	 start_x=-1,end_x=-1;
	 for (i=0;i<map_h;i++)
		 for (j=0;j<map_w;j++) {
			 if (map[i][j]=='s') map[i][j]=' ',start_x=j,start_y=i;
			 if (map[i][j]=='e') map[i][j]=' ',end_x=j,end_y=i;
			 }
	 assert(start_x>=0 && end_x>=0);
	 return 0;
}
void showmap()
{
	int i,j;
	clrscr();
	for (i=0;i<map_h;i++)
	{
		gotoxy(1,i+1);
		for (j=0;j<map_w;j++)
			if (map[i][j]!=' ') cprintf(\xdb);
			else cprintf( );
    }
	gotoxy(start_x+1,start_y+1);
	 cprintf(s);
	 gotoxy(end_x+1,end_y+1);
	 cprintf(e);
}
/*int main()
{
 int path[MAXINT];
 readmap();
 showmap();
 getch();
 findpath(path);
 printpath(path);
 getch();
 return 0;
}*/

             

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲二区视频在线| 久久新电视剧免费观看| 欧美一区二区日韩| 久久久久久日产精品| 亚洲品质自拍视频| 青青草国产成人av片免费| 国产乱码精品一品二品| 91亚洲精品一区二区乱码| 9191成人精品久久| 国产日韩欧美激情| 亚洲午夜电影网| 国产精品亚洲午夜一区二区三区 | 91精品国产综合久久精品性色| 日韩视频一区二区在线观看| 中文字幕不卡三区| 午夜久久福利影院| av在线综合网| 精品国产三级电影在线观看| 一区二区三区久久| 国产一区二区三区视频在线播放| 色婷婷久久久久swag精品 | 日韩av在线播放中文字幕| 国产成人啪午夜精品网站男同| 91精品中文字幕一区二区三区| 国产精品免费aⅴ片在线观看| 香蕉影视欧美成人| 成人av在线网站| 欧美一区二区三区影视| 亚洲图片激情小说| 国产一区二区成人久久免费影院| 欧美性色综合网| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 亚洲高清免费观看高清完整版在线观看| 久久精品99国产精品| 91豆麻精品91久久久久久| 久久一区二区三区四区| 午夜精品一区二区三区电影天堂 | 一区免费观看视频| 精品伊人久久久久7777人| 欧美性视频一区二区三区| 国产精品午夜电影| 国产精品综合av一区二区国产馆| 91精品国产美女浴室洗澡无遮挡| 一区二区在线观看视频| 国产ts人妖一区二区| 欧美变态口味重另类| 天天综合日日夜夜精品| 91成人免费在线视频| 久久精品网站免费观看| 日韩av高清在线观看| 欧美网站大全在线观看| 亚洲天堂精品视频| 99这里只有久久精品视频| 日本一区二区三区四区在线视频| 久久成人羞羞网站| 日韩欧美高清dvd碟片| 亚洲福利视频一区| 在线精品视频一区二区| 亚洲女性喷水在线观看一区| 成人av电影在线网| 国产精品色在线观看| 懂色av一区二区三区蜜臀| 久久久综合九色合综国产精品| 久久激情五月婷婷| 日韩一级免费观看| 蜜臀va亚洲va欧美va天堂| 在线播放/欧美激情| 日韩av高清在线观看| 欧美一级二级三级蜜桃| 日韩国产精品久久久久久亚洲| 制服丝袜中文字幕一区| 丝袜美腿一区二区三区| 欧美日韩视频一区二区| 天天色图综合网| 555夜色666亚洲国产免| 蜜臀国产一区二区三区在线播放| 欧美一区二区精美| 狠狠色2019综合网| 久久嫩草精品久久久精品一| 国产精品一区二区视频| 国产欧美一区二区三区网站| 懂色av中文一区二区三区| 中文av一区二区| av网站一区二区三区| 亚洲精品自拍动漫在线| 精品视频一区三区九区| 亚洲成av人**亚洲成av**| 欧美妇女性影城| 久久99精品久久久久久国产越南| 精品国产乱码久久久久久蜜臀| 国产精品123区| 国产精品久久久久久户外露出| 91麻豆自制传媒国产之光| 亚洲综合色网站| 日韩限制级电影在线观看| 国产一区二区三区视频在线播放| 国产精品进线69影院| 在线国产电影不卡| 麻豆免费看一区二区三区| 国产三级久久久| 色婷婷久久99综合精品jk白丝| 亚洲福利一二三区| 久久夜色精品一区| 91麻豆高清视频| 三级久久三级久久| 久久天天做天天爱综合色| 成人午夜免费电影| 亚洲高清中文字幕| 久久综合九色综合欧美就去吻| 99久久夜色精品国产网站| 亚洲狠狠爱一区二区三区| 欧美videossexotv100| 成人av网站大全| 99在线视频精品| 亚洲国产成人av好男人在线观看| 精品欧美一区二区在线观看 | 亚洲精品乱码久久久久久久久| 欧美疯狂性受xxxxx喷水图片| 国产精品原创巨作av| 一区二区三区欧美久久| 日韩精品在线看片z| 91免费看视频| 国内偷窥港台综合视频在线播放| 亚洲欧美福利一区二区| 日韩一级免费观看| 色综合天天在线| 久久aⅴ国产欧美74aaa| 一区二区三区四区五区视频在线观看| 日韩欧美国产三级| 91丝袜美腿高跟国产极品老师| 美女任你摸久久| 亚洲精品一二三四区| 精品久久国产97色综合| 一本大道综合伊人精品热热| 久久精品国产999大香线蕉| 亚洲美女屁股眼交3| 亚洲精品一区二区三区影院| 在线看日韩精品电影| 国内精品久久久久影院薰衣草| 一区二区三区成人在线视频| 久久日一线二线三线suv| 欧美视频一区二区三区四区| 国产91精品免费| 美国一区二区三区在线播放| 亚洲另类一区二区| 国产免费成人在线视频| 日韩亚洲欧美一区二区三区| 欧美午夜精品一区二区蜜桃 | 亚洲视频一区在线观看| 精品黑人一区二区三区久久 | 日韩中文字幕1| 亚洲色图欧美偷拍| 国产色综合久久| 日韩一级大片在线观看| 91福利在线播放| av在线这里只有精品| 国产精品1区2区3区在线观看| 日本美女一区二区三区视频| 一区二区三区影院| 亚洲三级在线免费观看| 国产精品色一区二区三区| 日韩视频永久免费| 欧美一区二区三区免费| 在线观看日韩一区| 99在线视频精品| av中文字幕亚洲| 播五月开心婷婷综合| 国产成人综合网站| 国产精品综合网| 国内精品第一页| 精品一区二区三区影院在线午夜| 日韩美女天天操| 91久久精品午夜一区二区| 国产激情一区二区三区| 自拍偷拍亚洲激情| 欧美日韩一区中文字幕| 亚洲天堂av一区| 91成人在线精品| 日韩综合在线视频| 国产精品成人一区二区三区夜夜夜 | 天堂蜜桃一区二区三区| 亚洲精品国产成人久久av盗摄| 中文字幕不卡在线| 欧美国产精品v| 国产精品护士白丝一区av| 1024精品合集| 亚洲视频网在线直播| 亚洲理论在线观看| 亚洲综合免费观看高清完整版| 亚洲色欲色欲www在线观看| 麻豆免费看一区二区三区| 亚洲乱码中文字幕| 日韩女优电影在线观看| 精品久久久久久久久久久久包黑料| 日韩欧美国产三级| 久久久久久久久久电影| 国产精品网站在线播放| 国产精品福利在线播放| 一区二区三区欧美亚洲| 日韩精品免费视频人成|