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

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

?? eveluation.cpp

?? VC寫的象棋游戲源代碼
?? CPP
字號:
// COPYRIGHT NOTES
// ---------------
// This source code is a part of chess which is an example of <Game Programing guide>.
// You may use, compile or redistribute it as part of your application 
// for free. 
// You cannot redistribute sources without the official agreement of the author. 
// If distribution of you application which contents code below was occured, place 
// e-mail <hidebug@hotmail.com> on it is to be appreciated.
// This code can be used WITHOUT ANY WARRANTIES on your own risk.
// 
// Spring Wang <hidebug@hotmail.com>

// ---------------
// 版權聲明
// ---------------
// 本文件所含之代碼是《人機博弈程序設計指南》的范例程序中國象棋的一部分
// 您可以免費的使用, 編譯 或者作為您應用程序的一部分。 
// 但,您不能在未經作者書面許可的情況下分發此源代碼。 
// 如果您的應用程序使用了這些代碼,在您的應用程序界面上 
// 放入 e-mail <hidebug@hotmail.com> 是令人欣賞的做法。
// 此代碼并不含有任何保證,使用者當自承風險。
// 
// 王小春 <hidebug@hotmail.com>

// Eveluation.cpp: implementation of the CEveluation class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "chess.h"
#include "Eveluation.h"

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

const int BA0[10][9]=
{
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{90,90,110,120,120,120,110,90,90},
	{90,90,110,120,120,120,110,90,90},
	{70,90,110,110,110,110,110,90,70},
	{70,70,70, 70, 70,  70, 70,70,70},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
};

const int BA1[10][9]=
{
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{0,  0,  0,  0,  0,  0,  0,  0,  0},
	{70,70,70, 70, 70,70, 70,70, 70},
	{70,90,110,110,110,110,110,90,70},
	{90,90,110,120,120,120,110,90,90},
	{90,90,110,120,120,120,110,90,90},
	{0,  0, 0,  0,  0,  0,  0,  0,  0},
};

int CEveluation:: GetBingValue(int x, int y, BYTE CurSituation[][9])
{
	if (CurSituation[y][x] == R_PAWN)
		return BA0[y][x];
	
	if (CurSituation[y][x] == B_PAWN)
		return BA1[y][x];

	return 0;
}

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
CEveluation::CEveluation()
{
	m_BaseValue[B_KING] = BASEVALUE_KING; 
	m_BaseValue[B_CAR] = BASEVALUE_CAR; 
	m_BaseValue[B_HORSE] = BASEVALUE_HORSE; 
	m_BaseValue[B_BISHOP] = BASEVALUE_BISHOP; 
	m_BaseValue[B_ELEPHANT] = BASEVALUE_ELEPHANT; 
	m_BaseValue[B_CANON] = BASEVALUE_CANON; 
	m_BaseValue[B_PAWN] = BASEVALUE_PAWN; 

	m_BaseValue[R_KING] = BASEVALUE_KING; 
	m_BaseValue[R_CAR] = BASEVALUE_CAR; 
	m_BaseValue[R_HORSE] = BASEVALUE_HORSE; 
	m_BaseValue[R_BISHOP] = BASEVALUE_BISHOP; 
	m_BaseValue[R_ELEPHANT] = BASEVALUE_ELEPHANT; 
	m_BaseValue[R_CANON] = BASEVALUE_CANON; 
	m_BaseValue[R_PAWN] = BASEVALUE_PAWN; 

	m_FlexValue[B_KING] = FLEXIBILITY_KING; 
	m_FlexValue[B_CAR] = FLEXIBILITY_CAR; 
	m_FlexValue[B_HORSE] = FLEXIBILITY_HORSE; 
	m_FlexValue[B_BISHOP] = FLEXIBILITY_BISHOP; 
	m_FlexValue[B_ELEPHANT] = FLEXIBILITY_ELEPHANT; 
	m_FlexValue[B_CANON] = FLEXIBILITY_CANON; 
	m_FlexValue[B_PAWN] = FLEXIBILITY_PAWN; 

	m_FlexValue[R_KING] = FLEXIBILITY_KING; 
	m_FlexValue[R_CAR] = FLEXIBILITY_CAR; 
	m_FlexValue[R_HORSE] = FLEXIBILITY_HORSE; 
	m_FlexValue[R_BISHOP] = FLEXIBILITY_BISHOP; 
	m_FlexValue[R_ELEPHANT] = FLEXIBILITY_ELEPHANT; 
	m_FlexValue[R_CANON] = FLEXIBILITY_CANON; 
	m_FlexValue[R_PAWN] = FLEXIBILITY_PAWN; 

}

CEveluation::~CEveluation()
{
}
int count=0;
int CEveluation::Eveluate(BYTE position[10][9], BOOL bIsRedTurn)
{
	int i, j, k;
	int nChessType, nTargetType;
	count++;

	memset(m_chessValue,0, 360);
	memset(m_AttackPos,0, 180); 
	memset(m_GuardPos,0, 90); 
	memset(m_FlexibilityPos, 0, 90);

	for(i = 0; i < 10; i++)
		for(j = 0; j < 9; j++)
		{
			if(position[i][j] != NOCHESS)
			{
				nChessType = position[i][j];
				GetRelatePiece(position, j, i);
				for (k = 0; k < nPosCount; k++)
				{
					nTargetType = position[RelatePos[k].y][RelatePos[k].x];
					if (nTargetType == NOCHESS)
					{
						m_FlexibilityPos[i][j]++;	
					}
					else
					{
						if (IsSameSide(nChessType, nTargetType))
						{
							m_GuardPos[RelatePos[k].y][RelatePos[k].x]++;
						}else
						{
							m_AttackPos[RelatePos[k].y][RelatePos[k].x]++;
							m_FlexibilityPos[i][j]++;	
							switch (nTargetType)
							{
							case R_KING:
								if (!bIsRedTurn)
									return 18888;
								break;
							case B_KING:
								if (bIsRedTurn)
									return 18888;
								break;
							default:
								m_AttackPos[RelatePos[k].y][RelatePos[k].x] += (30 + (m_BaseValue[nTargetType] - m_BaseValue[nChessType])/10)/10;
								break;
							}
						}
					}
				}
			}
		}

	for(i = 0; i < 10; i++)
		for(j = 0; j < 9; j++)
		{
			if(position[i][j] != NOCHESS)
			{
				nChessType = position[i][j];
				m_chessValue[i][j]++;
				m_chessValue[i][j] += m_FlexValue[nChessType] * m_FlexibilityPos[i][j];
				m_chessValue[i][j] += GetBingValue(j, i, position);
			}
		}
	int nHalfvalue;
	for(i = 0; i < 10; i++)
		for(j = 0; j < 9; j++)
		{
			if(position[i][j] != NOCHESS)
			{
				nChessType = position[i][j];
				nHalfvalue = m_BaseValue[nChessType]/16;
				m_chessValue[i][j] += m_BaseValue[nChessType];
				
				if (IsRed(nChessType))
				{
					if (m_AttackPos[i][j])
					{
						if (bIsRedTurn)
						{
							if (nChessType == R_KING)
							{
								m_chessValue[i][j]-= 20;
							}
							else
							{
								m_chessValue[i][j] -= nHalfvalue * 2;
								if (m_GuardPos[i][j])
									m_chessValue[i][j] += nHalfvalue;
							}
						}
						else
						{
							if (nChessType == R_KING)
								return 18888;
							m_chessValue[i][j] -= nHalfvalue*10;
							if (m_GuardPos[i][j])
								m_chessValue[i][j] += nHalfvalue*9;
						}
						m_chessValue[i][j] -= m_AttackPos[i][j];
					}
					else
					{
						if (m_GuardPos[i][j])
							m_chessValue[i][j] += 5;
					}
				}
				else
				{
					if (m_AttackPos[i][j])
					{
						if (!bIsRedTurn)
						{
							if (nChessType == B_KING)									
							{
								m_chessValue[i][j]-= 20;
							}
							else
							{
								m_chessValue[i][j] -= nHalfvalue * 2;
								if (m_GuardPos[i][j])
									m_chessValue[i][j] += nHalfvalue;
							}
						}
						else
						{
							if (nChessType == B_KING)
								return 18888;
							m_chessValue[i][j] -= nHalfvalue*10;
							if (m_GuardPos[i][j])
								m_chessValue[i][j] += nHalfvalue*9;
						}
						m_chessValue[i][j] -= m_AttackPos[i][j];
					}
					else
					{
						if (m_GuardPos[i][j])
							m_chessValue[i][j] += 5;
					}
				}
			}
		}

	int nRedValue = 0; 
	int	nBlackValue = 0;

	for(i = 0; i < 10; i++)
		for(j = 0; j < 9; j++)
		{
			nChessType = position[i][j];
//			if (nChessType == R_KING || nChessType == B_KING)
//				m_chessValue[i][j] = 10000;	
			if (nChessType != NOCHESS)
			{
				if (IsRed(nChessType))
				{
					nRedValue += m_chessValue[i][j];	
				}
				else
				{
					nBlackValue += m_chessValue[i][j];	
				}
			}
		}
		if (bIsRedTurn)
		{
			return nRedValue - nBlackValue;
		}
		else
		{
			return  nBlackValue-nRedValue ;
		}
}





CEveluation::AddPoint(int  x, int y)
{
	RelatePos[nPosCount].x = x;
	RelatePos[nPosCount].y = y;
	nPosCount++;
}

int CEveluation::GetRelatePiece(BYTE position[10][9], int j, int i)
{
	nPosCount = 0;
	BYTE nChessID;
	BYTE flag;
	int x,y;
	
	nChessID = position[i][j];
	switch(nChessID)
	{
	case R_KING:
	case B_KING:
		
		for (y = 0; y < 3; y++)
			for (x = 3; x < 6; x++)
				if (CanTouch(position, j, i, x, y))
					AddPoint(x, y);
		for (y = 7; y < 10; y++)
			for (x = 3; x < 6; x++)
				if (CanTouch(position, j, i, x, y))
					AddPoint(x, y);
		break;
						
	case R_BISHOP:
		
		for (y = 7; y < 10; y++)
			for (x = 3; x < 6; x++)
				if (CanTouch(position, j, i, x, y))
					AddPoint(x, y);
		break;
				
	case B_BISHOP:
		
		for (y = 0; y < 3; y++)
			for (x = 3; x < 6; x++)
				if (CanTouch(position, j, i, x, y))
					AddPoint(x, y);
		break;
				
	case R_ELEPHANT:
	case B_ELEPHANT:
		
		x=j+2;
		y=i+2;
		if(x < 9 && y < 10  && CanTouch(position, j, i, x, y))
			AddPoint(x, y);
		
		x=j+2;
		y=i-2;
		if(x < 9 && y>=0  &&  CanTouch(position, j, i, x, y))
			AddPoint(x, y);
		
		x=j-2;
		y=i+2;
		if(x>=0 && y < 10  && CanTouch(position, j, i, x, y))
			AddPoint(x, y);
		
		x=j-2;
		y=i-2;
		if(x>=0 && y>=0  && CanTouch(position, j, i, x, y))
			AddPoint(x, y);
		break;
		
		case R_HORSE:		
		case B_HORSE:		
			x=j+2;
			y=i+1;
			if((x < 9 && y < 10) &&CanTouch(position, j, i, x, y))
				AddPoint(x, y);
					
					x=j+2;
					y=i-1;
					if((x < 9 && y >= 0) &&CanTouch(position, j, i, x, y))
						AddPoint(x, y);
					
					x=j-2;
					y=i+1;
					if((x >= 0 && y < 10) &&CanTouch(position, j, i, x, y))
						AddPoint(x, y);
					
					x=j-2;
					y=i-1;
					if((x >= 0 && y >= 0) &&CanTouch(position, j, i, x, y))
						AddPoint(x, y);
					
					x=j+1;
					y=i+2;
					if((x < 9 && y < 10) &&CanTouch(position, j, i, x, y))
						AddPoint(x, y);
					x=j-1;
					y=i+2;
					if((x >= 0 && y < 10) &&CanTouch(position, j, i, x, y))
						AddPoint(x, y);
					x=j+1;
					y=i-2;
					if((x < 9 && y >= 0) &&CanTouch(position, j, i, x, y))
						AddPoint(x, y);
					x=j-1;
					y=i-2;
					if((x >= 0 && y >= 0) &&CanTouch(position, j, i, x, y))
						AddPoint(x, y);
					break;
					
				case R_CAR:
				case B_CAR:
					x=j+1;
					y=i;
					while(x < 9)
					{
						if( NOCHESS == position[y][x] )
							AddPoint(x, y);
						else
						{
							AddPoint(x, y);
							break;
						}
						x++;
					}
					
					x = j-1;
					y = i;
					while(x >= 0)
					{
						if( NOCHESS == position[y][x] )
							AddPoint(x, y);
						else
						{
							AddPoint(x, y);
							break;
						}
						x--;
					}
					
					x=j;
					y=i+1;//
					while(y < 10)
					{
						if( NOCHESS == position[y][x])
							AddPoint(x, y);
						else
						{
							AddPoint(x, y);
							break;
						}
						y++;
					}
					
					x = j;
					y = i-1;//

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜电影一区| 国产欧美一区二区三区在线看蜜臀 | 久久狠狠亚洲综合| 激情综合一区二区三区| 91精品国产综合久久久蜜臀图片| 色哦色哦哦色天天综合| 色婷婷综合久久久中文字幕| 99久久精品一区二区| 91久久免费观看| 色94色欧美sute亚洲线路一ni| 成人成人成人在线视频| 欧美影视一区在线| 精品视频免费看| 国产日韩欧美一区二区三区综合| 亚洲欧美一区二区三区孕妇| 中文字幕亚洲不卡| 日韩高清在线不卡| 国产高清亚洲一区| 97aⅴ精品视频一二三区| 欧美美女黄视频| 久久综合色一综合色88| 亚洲欧美日本韩国| 国产一区不卡精品| 欧美色区777第一页| 欧美国产成人精品| 老司机精品视频在线| 色婷婷久久综合| 国产精品免费人成网站| 日韩高清一区二区| 欧美视频日韩视频| 亚洲精品第1页| 不卡的av电影| 国产日韩欧美高清| 日欧美一区二区| 99久久精品免费看国产 | 美女脱光内衣内裤视频久久网站 | 久久久影院官网| 老司机午夜精品| 欧美mv和日韩mv的网站| 香蕉加勒比综合久久| 国产激情精品久久久第一区二区 | 国产91丝袜在线观看| 26uuu成人网一区二区三区| 婷婷一区二区三区| 69久久夜色精品国产69蝌蚪网| 午夜精品久久久久久久久| 在线观看免费一区| 亚洲精品写真福利| 欧美少妇xxx| 丝袜美腿亚洲一区| 日韩欧美成人激情| 国产成人综合在线播放| 国产精品视频免费看| 99视频有精品| 亚洲电影一级片| 日韩一区二区免费高清| 九九九精品视频| 国产日韩精品一区二区三区| 成人毛片视频在线观看| 亚洲品质自拍视频网站| 欧美精品久久久久久久多人混战 | 欧美剧情片在线观看| 久久不见久久见中文字幕免费| 精品国产伦一区二区三区观看方式| 极品销魂美女一区二区三区| 日本一区二区三区在线观看| 欧美日韩美少妇| 日韩高清在线不卡| 国产精品女主播av| 欧美色网一区二区| 国产毛片精品视频| 一卡二卡欧美日韩| 欧美激情一区二区在线| 91福利在线播放| 精品中文字幕一区二区| 亚洲综合久久av| 久久综合久久综合九色| 欧美在线观看视频一区二区| 精品制服美女久久| 亚洲午夜免费电影| 国产精品久久99| 欧美日韩中文字幕精品| 国产成人综合视频| 日韩电影免费在线观看网站| 国产日韩高清在线| 欧美一区二区三区爱爱| 99久久综合色| 国产精品一区在线| 丝袜亚洲另类丝袜在线| 国产精品国产馆在线真实露脸| 4438亚洲最大| 欧美日韩在线观看一区二区| 国产精品资源网| 黑人巨大精品欧美黑白配亚洲| 中文字幕欧美区| 精品乱人伦小说| 欧美成人免费网站| 欧美日韩亚洲不卡| 99视频在线观看一区三区| 国产成人精品网址| 久久国产精品99久久人人澡| 免费在线观看一区| 日韩成人精品在线| 麻豆视频一区二区| 国产成人亚洲综合a∨婷婷 | 国内精品久久久久影院薰衣草| 久久99深爱久久99精品| 国产精品99久久久久久有的能看 | 久久久99精品免费观看| 欧美一区二区三区不卡| 这里只有精品视频在线观看| 欧美日韩综合不卡| 日韩精品专区在线影院观看| 日韩一卡二卡三卡四卡| 久久精品男人天堂av| 国产精品国产三级国产a| 亚洲国产综合在线| 美女视频黄 久久| 亚洲高清不卡在线| 麻豆国产一区二区| 国产最新精品免费| 国产成人免费视频一区| 不卡影院免费观看| 色视频成人在线观看免| 欧美视频一区二| 欧美成人官网二区| 国产精品第一页第二页第三页| **欧美大码日韩| 亚洲一二三专区| 精品一区二区在线免费观看| 国产米奇在线777精品观看| 99视频一区二区| 在线播放国产精品二区一二区四区| 精品少妇一区二区三区日产乱码 | 欧美一区二区三区在| 精品久久国产老人久久综合| 国产日韩欧美在线一区| 玉足女爽爽91| 成熟亚洲日本毛茸茸凸凹| 欧美在线免费观看亚洲| 久久久久久夜精品精品免费| 亚洲女子a中天字幕| 国产美女一区二区三区| 99久久精品一区二区| 精品日本一线二线三线不卡| 18成人在线观看| 国产乱对白刺激视频不卡| 欧美色精品天天在线观看视频| 欧美xxxxx裸体时装秀| 亚洲免费成人av| 丁香婷婷综合五月| 精品久久人人做人人爰| 亚洲va韩国va欧美va| 色悠悠久久综合| 国产精品免费人成网站| 五月天网站亚洲| 色先锋aa成人| 国产精品女同一区二区三区| 另类的小说在线视频另类成人小视频在线| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 一区二区免费看| 99久久综合国产精品| 日本一区免费视频| 国产乱人伦偷精品视频免下载| 69堂亚洲精品首页| 日本欧美在线观看| 91精品国产综合久久久久久久| 午夜伊人狠狠久久| 欧美日本在线看| 国产在线不卡一区| 中文子幕无线码一区tr| 国产不卡视频一区| 亚洲天堂久久久久久久| 97久久久精品综合88久久| 国产精品国产a| 在线观看不卡视频| 婷婷一区二区三区| 久久精品亚洲乱码伦伦中文 | 亚洲视频综合在线| 色综合久久六月婷婷中文字幕| 一区二区三区中文字幕电影| 91精品国模一区二区三区| 国内外成人在线| 亚洲激情在线激情| 欧美一级高清大全免费观看| 成年人午夜久久久| 久久99蜜桃精品| 一区二区免费看| 国产精品丝袜久久久久久app| 欧美日韩中文字幕精品| 国产精品一区二区三区四区 | 日本麻豆一区二区三区视频| 国产日产欧美一区二区三区| 欧美视频一区二区在线观看| 91香蕉视频污在线| 亚洲成av人在线观看| 中文字幕中文在线不卡住| www国产成人免费观看视频 深夜成人网| 狠狠色丁香婷婷综合久久片| 久久精品一区二区三区不卡|