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

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

?? eveluation.cpp

?? 中國象棋人機博弈的書籍!PC游戲編程.安裝程序!
?? 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>

// ---------------
// 版權聲明
// ---------------
// 本文件所含之代碼是《人機博弈程序設計指南》的范例程序中國象棋的一部分
// 您可以免費的使用, 編譯 或者作為您應用程序的一部分。 
// 但,您不能在未經作者書面許可的情況下分發(fā)此源代碼。 
// 如果您的應用程序使用了這些代碼,在您的應用程序界面上 
// 放入 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一区二区三区免费野_久草精品视频
天堂成人免费av电影一区| 久久久综合网站| 性做久久久久久| 4438x亚洲最大成人网| 青青草精品视频| 欧美不卡在线视频| 国产成人亚洲综合a∨猫咪| 国产精品久久久一本精品| 一本一本大道香蕉久在线精品 | 国产日产欧美一区二区视频| 国产不卡在线一区| 亚洲视频一二三区| 欧美日韩中字一区| 黄页视频在线91| 亚洲视频一二三| 欧美日韩高清在线| 国产一区二区美女| 一区二区三区欧美在线观看| 日韩午夜激情电影| 成人av手机在线观看| 亚洲电影你懂得| 久久久久一区二区三区四区| 99久久精品国产导航| 日韩主播视频在线| 亚洲国产精品传媒在线观看| 欧美性猛交xxxx黑人交 | 国产九九视频一区二区三区| 亚洲欧洲精品天堂一级| 91精品国产综合久久久久久久久久| 狠狠狠色丁香婷婷综合久久五月| 最好看的中文字幕久久| 欧美一级电影网站| 91看片淫黄大片一级在线观看| 免费在线观看一区二区三区| 亚洲欧洲韩国日本视频| 精品国产91洋老外米糕| 在线看日本不卡| 粉嫩13p一区二区三区| 亚洲国产精品久久久男人的天堂| 国产日产欧美精品一区二区三区| 欧美日韩成人在线| 99麻豆久久久国产精品免费优播| 蜜桃视频一区二区| 亚洲国产精品自拍| 一区在线播放视频| 国产亚洲1区2区3区| 日韩一区二区视频在线观看| 色婷婷激情久久| 成人丝袜18视频在线观看| 美女免费视频一区二区| 亚洲国产另类av| 亚洲精品视频自拍| 亚洲欧洲国产日本综合| 久久久精品综合| 日韩欧美久久久| 在线播放/欧美激情| 色综合久久精品| 99久久婷婷国产综合精品| 国产成人亚洲综合a∨猫咪| 久久精品噜噜噜成人av农村| 同产精品九九九| 亚洲一二三专区| 有码一区二区三区| 亚洲美女屁股眼交3| 中文字幕精品一区| 久久综合九色综合欧美就去吻| 日韩一级二级三级| 日韩写真欧美这视频| 51精品国自产在线| 91精品国产欧美日韩| 9191国产精品| 欧美成人bangbros| 26uuu亚洲综合色欧美| 精品99999| 久久久久久一级片| 国产精品欧美一级免费| 亚洲欧洲精品天堂一级| 亚洲欧美另类小说视频| 亚洲最大成人网4388xx| 亚洲电影一区二区三区| 亚洲高清一区二区三区| 亚洲成av人片一区二区梦乃| 亚洲第一二三四区| 日韩高清国产一区在线| 老司机午夜精品| 国产尤物一区二区| 风间由美一区二区av101 | 裸体歌舞表演一区二区| 国内成人免费视频| 成年人午夜久久久| 日本久久精品电影| 91精品国产综合久久香蕉麻豆| 欧美一区二区福利视频| 久久亚洲捆绑美女| 国产精品电影一区二区三区| 一区二区国产盗摄色噜噜| 日韩福利视频网| 国产真实乱对白精彩久久| 成人免费va视频| 欧洲精品视频在线观看| 日韩欧美一区在线| 国产精品嫩草久久久久| 亚洲综合网站在线观看| 另类小说欧美激情| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 国产99精品国产| 色综合婷婷久久| 欧美日韩美少妇| 久久久久久久网| 一区二区三区欧美日韩| 国产精品自拍网站| 91丝袜美女网| 欧美一区二区美女| 国产精品久久久久久久第一福利 | 91在线看国产| 日韩视频在线观看一区二区| 国产欧美精品区一区二区三区| 一二三四社区欧美黄| 久久er精品视频| 在线免费观看日韩欧美| 26uuu成人网一区二区三区| 亚洲免费在线电影| 激情小说欧美图片| 欧美性受xxxx| 亚洲国产岛国毛片在线| 青青青伊人色综合久久| 99re成人精品视频| 久久人人97超碰com| 亚洲第四色夜色| 91一区一区三区| 久久男人中文字幕资源站| 亚洲五码中文字幕| 成人小视频免费观看| 精品少妇一区二区| 午夜久久电影网| 91国在线观看| 亚洲国产精品激情在线观看| 美女脱光内衣内裤视频久久网站| 色综合久久久久| 国产精品免费人成网站| 久久精品av麻豆的观看方式| 欧美主播一区二区三区| 欧美激情一区二区三区不卡| 久久99在线观看| 337p亚洲精品色噜噜狠狠| 亚洲精品自拍动漫在线| 懂色中文一区二区在线播放| 欧美大片一区二区| 免费久久精品视频| 69av一区二区三区| 亚洲第一综合色| 欧美色视频在线观看| 亚洲欧洲中文日韩久久av乱码| 风间由美性色一区二区三区| 久久久99久久精品欧美| 麻豆精品在线观看| 日韩一级片在线观看| 亚洲电影第三页| 欧美日韩国产美女| 五月天欧美精品| 在线综合+亚洲+欧美中文字幕| 亚洲成人免费在线观看| 欧美色欧美亚洲另类二区| 夜夜揉揉日日人人青青一国产精品| 97久久精品人人澡人人爽| 中文字幕一区二区在线观看 | 色av一区二区| 亚洲少妇最新在线视频| 93久久精品日日躁夜夜躁欧美| 国产精品久久久久久久久图文区| 国产成人综合网站| 中文子幕无线码一区tr| 91在线视频免费91| 亚洲精品一二三| 欧美三级日韩三级| 免费观看在线色综合| xnxx国产精品| 成人精品免费网站| 亚洲日本电影在线| 欧美亚洲国产一区二区三区va | 国产精品一二三四五| 久久嫩草精品久久久精品一| 粉嫩aⅴ一区二区三区四区五区 | 久久综合色综合88| 成人小视频免费在线观看| 亚洲色图色小说| 欧美性色黄大片| 久久精品久久久精品美女| 国产日韩亚洲欧美综合| 99久久精品免费看国产免费软件| 一区二区三区四区高清精品免费观看| 欧美视频中文一区二区三区在线观看| 五月天亚洲精品| 久久精品亚洲精品国产欧美kt∨| 成人黄页毛片网站| 婷婷激情综合网| 日本一区二区三区四区| 欧洲另类一二三四区| 国产麻豆一精品一av一免费| 中文字幕的久久|