亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
95精品视频在线| 国产一区 二区| 蜜臀a∨国产成人精品| 视频一区中文字幕| 国产传媒欧美日韩成人| 在线亚洲一区观看| 91麻豆精品国产91久久久| 欧美一级片在线| 国产精品传媒入口麻豆| 亚洲成人免费看| 久久国内精品自在自线400部| 成人aa视频在线观看| 制服.丝袜.亚洲.中文.综合| 91高清视频免费看| 日韩视频永久免费| 中文字幕日本乱码精品影院| 青青草97国产精品免费观看无弹窗版| 国产精品99久久久久久久女警| 99国产精品久久久| 精品久久五月天| 一级女性全黄久久生活片免费| 日韩av电影免费观看高清完整版 | 久久亚洲精精品中文字幕早川悠里| 久久久久久影视| 久久成人麻豆午夜电影| 欧美日韩精品欧美日韩精品一 | eeuss国产一区二区三区| 欧美一区二区大片| 亚洲国产日日夜夜| 成人aa视频在线观看| 国产三级久久久| 久草热8精品视频在线观看| 日本韩国精品在线| 亚洲色图丝袜美腿| 91理论电影在线观看| 免费成人美女在线观看| 欧美国产一区二区在线观看| 日韩中文欧美在线| 7878成人国产在线观看| 亚洲国产精品一区二区久久| 在线精品国精品国产尤物884a| 亚洲色图另类专区| 欧美喷潮久久久xxxxx| 午夜精品爽啪视频| 欧美不卡一二三| 国产一区二区三区免费播放| 国产偷v国产偷v亚洲高清| 成人免费视频一区| 亚洲美女一区二区三区| 欧美揉bbbbb揉bbbbb| 美女一区二区视频| 欧美经典一区二区| 色诱亚洲精品久久久久久| 蜜桃在线一区二区三区| 中文字幕中文字幕中文字幕亚洲无线| 91精品国产综合久久精品图片 | 欧美伊人精品成人久久综合97| 亚洲一区二区精品久久av| 亚洲美女视频在线观看| 欧美一区二区日韩| a级精品国产片在线观看| 亚洲午夜久久久久久久久电影院 | 国产在线精品一区二区夜色| 亚洲久本草在线中文字幕| 久久尤物电影视频在线观看| 在线亚洲一区观看| 日韩欧美亚洲国产另类| 欧美综合久久久| 99久久99久久精品国产片果冻| 九九精品视频在线看| 日韩av电影一区| 亚洲午夜久久久久| 亚洲人成精品久久久久久| 久久精品亚洲精品国产欧美| 91精品国产手机| 91精品国产91久久综合桃花| 色综合网站在线| 色域天天综合网| 欧美日韩国产区一| 欧美老年两性高潮| 欧美精品一二三| 制服丝袜中文字幕一区| 欧美精品aⅴ在线视频| 精品视频一区二区不卡| 欧美美女一区二区在线观看| 欧美三级一区二区| 91精品国产日韩91久久久久久| 欧美日韩精品欧美日韩精品一综合| 欧美系列一区二区| 欧美精品一卡二卡| 2023国产精品自拍| 亚洲欧洲精品一区二区精品久久久| 亚洲色图欧洲色图| 肉色丝袜一区二区| 激情成人午夜视频| 91尤物视频在线观看| 在线观看日韩国产| 精品国产91久久久久久久妲己| 久久久蜜桃精品| 亚洲国产美国国产综合一区二区| 美腿丝袜亚洲三区| 91丨porny丨国产入口| 日韩精品资源二区在线| 亚洲精品视频免费看| 久久er99精品| 欧美日韩日日骚| 国产精品伦一区二区三级视频| 午夜精品久久久久久久久久| av不卡在线观看| 26uuu久久综合| 一区二区国产视频| 成人av一区二区三区| 日韩午夜av一区| 国产精品一区二区你懂的| 欧美日本精品一区二区三区| 日韩理论片在线| 懂色av一区二区三区蜜臀| 91精品在线免费观看| 午夜精品福利一区二区蜜股av | 欧美岛国在线观看| 天天亚洲美女在线视频| 色哟哟一区二区在线观看| 国产日本亚洲高清| 国产精品亚洲专一区二区三区| 在线播放中文一区| 亚洲bt欧美bt精品| 欧美一区欧美二区| 麻豆视频一区二区| 久久久久久免费毛片精品| 中文字幕免费在线观看视频一区| 奇米一区二区三区| 欧美精品一区二区高清在线观看| 琪琪久久久久日韩精品| 精品美女一区二区三区| 久久国产婷婷国产香蕉| 精品久久久影院| 国产**成人网毛片九色| 欧美极品美女视频| 欧美日韩在线不卡| 蜜乳av一区二区三区| 国产亚洲精品中文字幕| 色哟哟国产精品| 日韩—二三区免费观看av| 在线国产电影不卡| 椎名由奈av一区二区三区| 91香蕉国产在线观看软件| 丝袜脚交一区二区| 日本一区二区免费在线观看视频| 91香蕉视频在线| 蜜桃传媒麻豆第一区在线观看| 国产日韩视频一区二区三区| 色哟哟精品一区| 国产激情视频一区二区三区欧美| 亚洲精品乱码久久久久久黑人| 日韩一区二区麻豆国产| 91小视频在线| 国产成人免费视频网站 | 一区二区三区在线免费| av一区二区三区黑人| 成人听书哪个软件好| 午夜激情综合网| 一色桃子久久精品亚洲| 国产欧美一二三区| 日韩精品中文字幕一区 | 最近日韩中文字幕| 国产精品欧美极品| 国产欧美精品一区二区色综合朱莉 | 国产剧情在线观看一区二区| 亚洲成a人片综合在线| 亚洲一区视频在线观看视频| 中文字幕欧美区| 亚洲三级久久久| 午夜精品一区二区三区免费视频| 欧美日本一区二区在线观看| 日韩成人精品在线观看| 亚洲欧美视频一区| 国产精品福利av| 亚洲另类中文字| 国产高清视频一区| 亚洲欧美韩国综合色| 日韩理论片一区二区| 亚洲视频狠狠干| 亚洲精品欧美在线| 一区二区在线观看不卡| 亚洲午夜精品在线| 日韩国产精品久久| 免费观看一级欧美片| 日韩精品福利网| 精品制服美女久久| 国产精品乡下勾搭老头1| 高清国产一区二区三区| 处破女av一区二区| 欧美三片在线视频观看| 精品久久五月天| 综合色天天鬼久久鬼色| 亚洲v精品v日韩v欧美v专区 | 日韩电影一区二区三区四区| 成人午夜看片网址| 3751色影院一区二区三区| 中文字幕亚洲一区二区av在线 |