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

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

?? a_star_m_c.c

?? 使用A*算法解決傳教士與野人的問題
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*********************************************************************************
 *          程  序  說  明                                                       *
 * 功能: 用A*算法求解傳教士與野人問題。M=C=5, K=3                                *
 * 說明:                                                                         *
 *     本程序按照《人工智能導論》一書所介紹的A*算法求解傳教士與野人問題。        *
 *                                                                               *
 * 注意: 該程序盡可能用與算法一致的思路實現算法, 力求簡單明了, 注重算法的清晰性,*
 * 而沒有考慮算法的效率問題。                                                    *
 *********************************************************************************/

#include <stdio.h>
#include <stdlib.h>

#define		M	5		//傳教士總人數
#define		C	5		//野人總人數
#define		K	3		//船一次可以乘坐的最多人數

struct NODE
{
	int m;						//在左岸的傳教士人數
	int c;						//在左岸的野人人數
	int b;						//b=1表示船在左岸,b=0表示船在右岸
	double g;					//該節點的g值
	double f;					//該節點的f值
	struct NODE *pFather;		//指向該節點的父節點
	struct NODE *pNext;			//在OPEN表或者CLOSED表中,指向下一個元素
};

struct NODE *g_pOpen = NULL;	//全程變量,OPEN表
struct NODE *g_pClosed = NULL;		//全程變量,CLOSED表


int Equal(struct NODE *pNode1, struct NODE *pNode2)
/******************************************************
 * 功能:判斷兩個節點所表示的狀態是否相等             *
 *                                                    *
 * 入口參數:                                         *
 *   pNode1:指向節點1的指針                          *
 *   pNode2:指向節點2的指針                          *
 *                                                    *
 * 返回值:當兩個節點所表示的狀態相等時,返回1,否則  *
 *         返回0                                      *
 ******************************************************/
{
	if (pNode1->m == pNode2->m &&
		pNode1->c == pNode2->c &&
		pNode1->b == pNode2->b) return 1;
	else return 0;
}

struct NODE *NewNode(int m, int c, int b)
/******************************************************
 * 功能:動態產生一個節點,其狀態值由參數m,c,b給定。*
 *                                                    *
 * 入口參數:                                         *
 *   m:河左岸的傳教士人數                            *
 *   c:河左岸的野人人數                              *
 *   b:船是否在左岸,1:表示在左岸,0:表示不在左岸  *
 *                                                    *
 * 返回值:指向新產生的節點的指針,或者空間不夠時,返 *
 *         回NULL                                     *
 ******************************************************/
{
	struct NODE *pNode = NULL;
	pNode = malloc(sizeof(struct NODE));
	if (pNode == NULL) return NULL;
	pNode->m = m;
	pNode->c = c;
	pNode->b = b;
	pNode->g = 0;
	pNode->f = 0;
	pNode->pFather = NULL;
	pNode->pNext = NULL;
	return pNode;
}

void FreeList(struct NODE *pList)
/******************************************************
 * 功能:釋放動態產生的鏈表                           *
 *                                                    *
 * 入口參數:                                         *
 *   pList:指向OPEN表或者CLOSED表的指針              *
 *                                                    *
 * 返回值:無                                         *
 ******************************************************/
{
	struct NODE *pNode = NULL;
	while (pList)
	{
		pNode = pList;
		pList = pList->pNext;
		free(pNode);
	}
}

struct NODE *In(struct NODE *pNode, struct NODE *pList)
/******************************************************
 * 功能:判斷一個節點是否在一個鏈表中                 *
 *                                                    *
 * 入口參數:                                         *
 *   pNode:指向給定節點的指針                        *
 *   pList:指向給點鏈表的指針                        *
 *                                                    *
 * 返回值:當pNode在pList中時,返回以pNode為首的鏈表  *
 *         的后一部分;否則返回NULL                   *
 ******************************************************/
{
	if (pList == NULL) return NULL;
	if (Equal(pNode, pList)) return pList;
	return In(pNode, pList->pNext);
}

struct NODE *Del(struct NODE *pNode, struct NODE *pList)
/******************************************************
 * 功能:從鏈表pList中刪除節點pNode                   *
 *                                                    *
 * 入口參數:                                         *
 *   pNode:指向給定節點的指針                        *
 *   pList:指向給定的鏈表                            *
 *                                                    *
 * 返回值:刪除給定節點后的鏈表                       *
 ******************************************************/
{
	if (pList == NULL) return pList;
	if (Equal(pNode, pList)) return pList->pNext;
	pList->pNext = Del(pNode, pList->pNext);
	return pList;
}

struct NODE *AddToOpen(struct NODE *pNode, struct NODE *pOpen)
/******************************************************
 * 功能:將一個節點按照f值(從小到大)插入到OPEN表中  *
 *                                                    *
 * 入口參數:                                         *
 *   pNode: 指向給定節點的指針                        *
 *   pOpen:指向OPEN表的指針                          *
 *                                                    *
 * 返回值:指向插入給定節點后OPEN表的指針             *
 *                                                    *
 * 注意:同一個節點(具有相同指針的一個節點),只能向 *
 *       表中添加一次,否則可能會造成循環鏈表         *
 ******************************************************/
{
	if (pOpen == NULL)	//OPEN表為空
	{
		pNode -> pNext = NULL;
		return pNode;	
	}
	if (pNode->f < pOpen->f)	//給定節點的f值小于OPEN表第一個節點的f值
	{
		pNode->pNext = pOpen;	//插入到OPEN的最前面
		return pNode;
	}
	pOpen->pNext = AddToOpen(pNode, pOpen->pNext);	//遞歸
	return pOpen;
}

struct NODE *AddToClosed(struct NODE *pNode, struct NODE *pClosed)
/******************************************************
 * 功能:將一個節點插入到CLOSED表中                   *
 *                                                    *
 * 入口參數:                                         *
 *   pNode: 指向給定節點的指針                        *
 *   pClosed:指向CLOSED表的指針                      *
 *                                                    *
 * 返回值:指向插入給定節點后CLOSED表的指針           *
 *                                                    *
 * 注意:同一個節點(具有相同指針的一個節點),只能向 *
 *       表中添加一次,否則可能會造成循環鏈表         *
 ******************************************************/
{
	pNode->pNext = pClosed;
	return pNode;
}

void PrintList(struct NODE *pList)
/******************************************************
 * 功能:在屏幕上打印一個鏈表,用于調試程序           *
 *                                                    *
 * 入口參數:                                         *
 *   pList:指向鏈表的指針                            *
 *                                                    *
 * 返回值:無                                         *
 ******************************************************/
{
	while (pList)	//依次打印鏈表
	{
		printf("((%d %d %d) %f %f)\n", pList->m, pList->c, pList->b, pList->g, pList->f);
		pList = pList->pNext;
	}
}

void PrintNode(struct NODE *pNode)
/******************************************************
 * 功能:在屏幕上打印一個節點,用于調試程序           *
 *                                                    *
 * 入口參數:                                         *
 *   pNode:指向節點的指針                            *

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
狠狠色丁香婷婷综合| 性做久久久久久免费观看| 91老师国产黑色丝袜在线| 亚洲国产精品久久久久秋霞影院| 久久久久国产免费免费| 成人动漫一区二区在线| 一区二区三区不卡视频在线观看| 欧美大片拔萝卜| 色婷婷av一区| 久久精品久久久精品美女| 亚洲激情五月婷婷| 欧美成人精品1314www| 99re亚洲国产精品| 国产老妇另类xxxxx| 亚洲国产日韩一区二区| 久久久精品天堂| 91精品国产一区二区三区蜜臀| 国产成人丝袜美腿| 秋霞av亚洲一区二区三| 亚洲国产精品久久人人爱蜜臀| 久久精品一区八戒影视| a4yy欧美一区二区三区| 国产自产高清不卡| 一区二区三区在线高清| 日韩欧美在线网站| 欧美剧在线免费观看网站| 成人爽a毛片一区二区免费| 一区二区三区在线免费播放| 国产精品日日摸夜夜摸av| 欧美一区二区三区性视频| 一本色道**综合亚洲精品蜜桃冫| 国产精品自拍毛片| 秋霞av亚洲一区二区三| 日韩电影免费在线| 亚洲一区二区精品3399| 国产精品网站一区| 久久免费国产精品| 日韩欧美一区在线| 欧美日韩在线综合| 色哟哟一区二区三区| 久久精品国产精品亚洲红杏| 性做久久久久久免费观看| 一区二区三区美女| 一色屋精品亚洲香蕉网站| 久久看人人爽人人| 久久久精品影视| 精品国产伦一区二区三区免费 | 亚洲免费资源在线播放| 国产人伦精品一区二区| 欧美精品一区二区精品网| 欧美精品aⅴ在线视频| 日韩午夜在线影院| 日韩欧美国产一二三区| 91精品在线观看入口| 日韩免费视频一区| 日韩欧美国产1| 色天使色偷偷av一区二区| 色婷婷综合激情| 色屁屁一区二区| 欧美日韩大陆在线| 欧美伦理视频网站| 91精品国产综合久久国产大片| 欧美成人精品3d动漫h| 337p日本欧洲亚洲大胆色噜噜| 欧美va日韩va| 国产精品乱子久久久久| 国产精品毛片久久久久久| 久久久久久免费网| 亚洲三级免费观看| 亚洲激情图片qvod| 美女任你摸久久| 国内精品写真在线观看| 国产精品一卡二卡在线观看| 色综合亚洲欧洲| 欧美一a一片一级一片| 欧美日韩第一区日日骚| 欧美成人精品1314www| 久久久久九九视频| 精品一区二区久久久| 国产一区二区在线观看免费| 福利一区二区在线| 在线观看亚洲专区| 制服丝袜日韩国产| 国产精品麻豆久久久| 一区二区三区免费| 亚洲一区二区在线视频| 日本中文在线一区| 国产成人aaa| 欧美日韩精品一区二区天天拍小说| 欧美日韩国产bt| 欧美精品一区二区三| 一个色在线综合| 美国欧美日韩国产在线播放| 亚洲欧洲精品成人久久奇米网| 亚洲成av人片在www色猫咪| 国内精品国产三级国产a久久| 国产精品影视天天线| 一本一道久久a久久精品综合蜜臀| 欧美性受极品xxxx喷水| 精品福利av导航| 亚洲日本va在线观看| 日韩激情中文字幕| 91原创在线视频| 日韩午夜av电影| 日本一区二区三级电影在线观看| 偷拍自拍另类欧美| 国产成人8x视频一区二区| 99re这里只有精品视频首页| 日韩欧美亚洲国产精品字幕久久久| 亚洲欧洲一区二区在线播放| 美女网站色91| 色综合久久99| 26uuu亚洲| 日韩av不卡一区二区| 99精品热视频| 精品成人在线观看| 亚洲成人av福利| 99久久综合国产精品| 欧美激情在线一区二区三区| 日韩高清中文字幕一区| 国产成都精品91一区二区三| 欧美一区二区成人| 亚洲综合一区二区| 狠狠色狠狠色综合系列| 欧美日韩在线播| 中文字幕中文乱码欧美一区二区| 激情六月婷婷久久| 欧美日韩国产不卡| 欧美激情一二三区| 粉嫩欧美一区二区三区高清影视| 欧美一区二区三区四区五区| 亚瑟在线精品视频| 一本色道久久综合亚洲aⅴ蜜桃| 国产亚洲污的网站| 黑人精品欧美一区二区蜜桃| 欧美日韩国产美| 一区二区三区鲁丝不卡| 成人黄色综合网站| 欧美激情综合五月色丁香| 国产精品18久久久久| 日韩午夜在线影院| 亚洲一线二线三线视频| 欧美色中文字幕| 亚洲精品乱码久久久久久| 99精品在线免费| 亚洲视频一二三区| 成人国产电影网| 中文字幕亚洲综合久久菠萝蜜| 国产精品88av| 欧美电影免费观看高清完整版| 麻豆精品一区二区av白丝在线| 91福利区一区二区三区| 亚洲午夜久久久久久久久久久| 91在线精品一区二区| 亚洲精选免费视频| 色哟哟一区二区在线观看| 悠悠色在线精品| 欧美精品在线一区二区| 天涯成人国产亚洲精品一区av| 欧美一区二区三区在线观看| 麻豆精品久久精品色综合| 日韩区在线观看| 成人综合激情网| 国产精品每日更新在线播放网址| 色偷偷88欧美精品久久久| 亚洲综合丝袜美腿| 欧美日韩国产中文| 国产在线精品一区二区三区不卡| 久久综合av免费| 91老师片黄在线观看| 亚洲成人av一区二区三区| 91国偷自产一区二区开放时间| 五月婷婷综合在线| 欧美电影免费观看高清完整版| 成人激情午夜影院| 亚洲永久精品国产| 欧美性生活一区| 久久精品国产亚洲高清剧情介绍| 欧美成人vr18sexvr| 99久久精品99国产精品| 亚洲美女偷拍久久| 91福利区一区二区三区| 国产综合成人久久大片91| 自拍av一区二区三区| 欧美精品乱人伦久久久久久| 麻豆视频一区二区| 中国av一区二区三区| 欧美网站一区二区| 国产在线日韩欧美| 亚洲大片一区二区三区| 欧美精品一区二区在线播放| 91免费版在线| 秋霞国产午夜精品免费视频| 久久综合九色综合97_久久久| 91福利资源站| 国产一区二区三区香蕉| 亚洲高清免费视频| 久久蜜臀中文字幕| 蜜桃视频在线观看一区二区| 亚洲精品免费看|