我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C/C++实现经典象棋游戏的示例代码

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C/C++实现经典象棋游戏的示例代码

大体思路

采用面相过程的设计方式实现,类似于我们平时做的课程设计,实现这样的小游戏无非就是多了图形处理库。这里使用的是acllib图形库。

设计这种小游戏,首先要从宏观上去认识:象棋,要有棋盘,要有棋子,棋子要移动。

对于棋盘,十行九列画出即可。

对于棋子,分黑红两方,按照指定位置画出。

如何移动棋子,我们有mouseEvent函数。

初始化棋盘棋子:initmap,initpaint

利用鼠标实现棋子移动分两步(mouseEvent):

第一次点击,记录点击棋子的信息

第二次点击,将第一次点击记录的棋子信息移动到第二次点击的位置。

最后在添加亿点细节。

  • 首先画棋盘——chessboard()
  • 初始化棋子信息——initmp()
  • 将棋子画到棋盘上——initpaint()
  • 注册鼠标,通过鼠标点击不同位置实现棋子的移动(按照象棋行棋规范)——mouseEvent(int x, int y, int button, int e)x、y为点击位置,button(鼠标左右键与滑轮)、e(点击或抬起)为事件。
  • 行棋规范——judge_piece(int x, int y)代表能否从上一步走到x,y处。

此外,实现象棋必然缺不了人机对战。对于人机算法我们可以采用最简单的遍历。每次遍历获取所有人机方棋子能走的地方,然后根据评估函数找出这些步中对人机方来说收益最大的一步。思路很简单,但是想写出走一步看很多步的算法也很难。首先评估函数要尽量具有代表性,这直接决定了人机的棋力;其次需要迭代遍历,这样次数多了时间复杂度就会很高。

这里只写了走一步看一步的人机代码供参考,更深入的可以自行去了解:

1、void Get_All_path()——获取人机所有可能走的方式(将step存入向量v中)

2、int calculate_value()——评估函数

3、void Get_max_way()——得到对人机最有利的那一步(传到prex,prey与nowx,nowy中,即从pre走到now)。

效果展示

核心代码

struct step
{
	int x1, y1, x2, y2;
};//从x1,y1走到x2,y2
void Get_All_path()
{
	v.clear();//全局变量
	step temp;
	for (int a = 0; a < 16; a++)
	{
		if (black_chess[a].is == 0)continue;
		prex = black_chess[a].row;
		prey = black_chess[a].col;
		temp.x1 = prex;
		temp.y1 = prey;
		for(int i=0;i<10;i++)
			for (int j = 0; j < 9; j++)
			{
				temp.x2 = i;
				temp.y2 = j;
				if (judge_piece(i, j) == 1&&mp[i][j].color!='B')
				{
					v.push_back(temp);
				}
			}
	}
}
int calculate_value()
{
	int sum1 = 0, sum2 = 0;
	for(int a=0;a<10;a++)
		for (int b = 0; b < 9; b++)
		{
			if (mp[a][b].color == 'B' && mp[a][b].is == 1)
			{
				switch (mp[a][b].index)
				{
				case 0:
					sum1 += 100;
					break;
				case 1:
					sum1 += 50;
					break;
				case 2:
					sum1 += 10;
				case 3:
					sum1 += 10;
					break;
				case 4:
					sum1 += 1500;
					break;
				case 5:
					sum1 += 50;
					break;
				case 6:
					sum1 += 20;
					break;
				default:
					break;
				}
			}
			else if (mp[a][b].color == 'R' && mp[a][b].is == 1)
			{
				switch (mp[a][b].index)
				{
				case 7:
					sum2 += 100;
					break;
				case 8:
					sum2 += 50;
					break;
				case 9:
					sum2 += 10;
				case 10:
					sum2 += 10;
					break;
				case 11:
					sum2 += 1500;
					break;
				case 12:
					sum2 += 50;
					break;
				case 13:
					sum2 += 20;
					break;
				default:
					break;
				}
			}
		}
	return sum1 - sum2;
}
void Get_max_way()
{
	//step ans;
	int minn = -150000;
	int calculate;
	Get_All_path();
	for (int a = 0; a<v.size(); a++)
	{
		int f = 1;
		int index= mp[v[a].x2][v[a].y2].index;
		int pos=0;
		int generalx=mp[v[a].x1][v[a].y1].row, generaly= mp[v[a].x1][v[a].y1].col;
		if (mp[v[a].x2][v[a].y2].color == 'R')//黑方吃子
		{
			if (mp[v[a].x2][v[a].y2].pos == 1)//被吃掉的为南兵
			{
				pos = 1;
				mp[v[a].x2][v[a].y2].pos = 0;
			}
			if (mp[v[a].x1][v[a].y1].index == 4)//黑将移动
			{
				black_general_x = v[a].x2;
				black_general_y = v[a].y2;
			}
			mp[v[a].x1][v[a].y1].is = 0;
			mp[v[a].x1][v[a].y1].color = NULL;
			mp[v[a].x2][v[a].y2].is = 1;
			mp[v[a].x2][v[a].y2].color = 'B';
			mp[v[a].x2][v[a].y2].index = mp[v[a].x1][v[a].y1].index;
		}
		else
		{
			f = 0;
			if (mp[v[a].x1][v[a].y1].index == 4)
			{
				black_general_x = v[a].x2;
				black_general_y = v[a].y2;
			}
			mp[v[a].x1][v[a].y1].is = 0;
			mp[v[a].x1][v[a].y1].color = NULL;
			mp[v[a].x2][v[a].y2].is = 1;
			mp[v[a].x2][v[a].y2].color = 'B';
			mp[v[a].x2][v[a].y2].index = mp[v[a].x1][v[a].y1].index;
		}
		calculate = calculate_value();
		if (minn < calculate)
		{
			prex = v[a].x1;
			prey = v[a].y1;
			minn = calculate;
			nowx = v[a].x2;
			nowy = v[a].y2;
		}
		//printf("%d\n", minn);
		if (f == 1)
		{
			
			mp[v[a].x2][v[a].y2].pos = pos;
			if (mp[v[a].x2][v[a].y2].index == 4)
			{
				black_general_x = generalx;
				black_general_y = generaly;
			}
			mp[v[a].x1][v[a].y1].is = 1;
			mp[v[a].x1][v[a].y1].color = 'B';
			mp[v[a].x1][v[a].y1].index = mp[v[a].x2][v[a].y2].index;
			mp[v[a].x2][v[a].y2].color = 'R';
			mp[v[a].x2][v[a].y2].index = index;
			mp[v[a].x2][v[a].y2].is = 1;
		}
		else
		{
			if (mp[v[a].x2][v[a].y2].index == 4)
			{
				black_general_x = generalx;
				black_general_y = generaly;
			}
				mp[v[a].x1][v[a].y1].is = 1;
				mp[v[a].x1][v[a].y1].color = 'B';
				mp[v[a].x1][v[a].y1].index = mp[v[a].x2][v[a].y2].index;
				mp[v[a].x2][v[a].y2].color = NULL;
				mp[v[a].x2][v[a].y2].index = index;
				mp[v[a].x2][v[a].y2].is = 0;
		}
	}
	//printf("%d\n", v.size());
	//printf("%d\n", minn);
	//return ans;
}

不含人机的代码如下:

#include"acllib.h"
#include<math.h>
#include<stdio.h>
#include<queue>
#define INTERVAL 50
using namespace std;
ACL_Image chessimg;
const double pi = 3.14;
//左上角为:(102,100)
// width:55
//height:55
//棋盘大小:440*495
//棋子半径:20
const char* chessname[] = { "車","馬","象","士","将","炮","卒","车","马","相","仕","帥","砲","兵" };
struct piece
{
	int x, y;
	int index;
	int is;
	char color;
	int pos;//兵 卒是否过河
	int row, col;
};
deque<piece>q;//悔棋——三步
void paint(piece s);
struct piece mp[10][9];
void initmp();
void initpaint();
void mouseEvent(int x, int y, int button, int e);
void paint_rect(int tmpx, int tmpy);
int judge_piece(int x, int y);
void chessboard();
int mouseflag = 0;
int prex, prey;
int black_general_x = 0, black_general_y = 4, black_general_isexist = 1;
int red_general_x = 9, red_general_y = 4, red_general_isexist = 1;
piece tmp;
int judge_general(int x, int y);
int Setup()
{
	//initConsole();
	initWindow("chess", DEFAULT, DEFAULT, 650, 701);
	chessboard();
	//loadImage("qipan.bmp", &chessimg);
	
	registerMouseEvent(mouseEvent);
	//paint(piece s);
	initmp();
	initpaint();
	return 0;
}
void mouseEvent(int x, int y, int button, int e)
{
	if (button == LEFT_BUTTON && e == BUTTON_DOWN)
	{
		if (x >= INTERVAL + 8 * 55 + 33 && x <= INTERVAL + 8 * 55 + 33 + 100 && y >= INTERVAL + 55 && y <= INTERVAL + 55 + 100)// INTERVAL + 8 * 55 + 33, INTERVAL + 55)
		{
			
			if (!q.empty())
			{
				piece p1 = q.back();
				q.pop_back();
				piece p2 = q.back();
				q.pop_back();
				//piece p3 = p1;
				mp[p1.row][p1.col].color = p1.color;
				mp[p1.row][p1.col].index = p1.index;
				mp[p1.row][p1.col].is = p1.is;
				mp[p1.row][p1.col].pos = p1.pos;
				mp[p2.row][p2.col].color = p2.color;
				mp[p2.row][p2.col].index = p2.index;
				mp[p2.row][p2.col].is = p2.is;
				mp[p2.row][p2.col].pos = p2.pos;
				initpaint();
			}
		}
		int tmpx, tmpy, f = 0;
		for (int a = 0; a < 10; a++)
		{
			if (f == 1)break;
			for (int b = 0; b < 9; b++)
			{
				if (sqrt(((double)x - mp[a][b].x) * ((double)x - mp[a][b].x) + ((double)y - mp[a][b].y) * ((double)y - mp[a][b].y)) <= 20)
				{
					f = 1;
					tmpx = a;
					tmpy = b;
					break;
				}
			}
		}
		if (f == 1)//有格子
		{
			initpaint();
			//paint_rect(tmpx, tmpy);
			
			if (mp[tmpx][tmpy].is == 1)//格子内有棋子
			{
				if (tmp.color == mp[tmpx][tmpy].color || tmp.color == NULL)//同色copy
				{
					paint_rect(tmpx, tmpy);
					prex = tmpx;
					prey = tmpy;
					tmp.is = mp[tmpx][tmpy].is;
					tmp.index = mp[tmpx][tmpy].index;
					tmp.color = mp[tmpx][tmpy].color;
				}
				else if (judge_piece(tmpx, tmpy) == 1)    //异色吃掉
				{
					q.push_back(mp[tmpx][tmpy]);
					q.push_back(mp[prex][prey]);
					while (q.size() > 6) {
						q.pop_front();
						q.pop_front();
					}
					if (mp[tmpx][tmpy].pos == 1)//若被吃掉的是南兵
					{
						mp[tmpx][tmpy].pos = 0;
					}
					else if (mp[prex][prey].pos == 1)//南兵吃别人
					{
						mp[prex][prey].pos = 0;
						mp[tmpx][tmpy].pos = 1;
					}
					if (mp[prex][prey].index == 4)//若是黑将移动,黑将位置重新赋值
					{
						black_general_x = tmpx;
						black_general_y = tmpy;
					}
					else if (mp[prex][prey].index == 11)//若是红将移动,红将位置重新赋值
					{
						red_general_x = tmpx;
						red_general_y = tmpy;
					}
					if (mp[tmpx][tmpy].index == 11)
						red_general_isexist = 0;
					else if (mp[tmpx][tmpy].index == 4)
						black_general_isexist = 0;
					mp[tmpx][tmpy].color = tmp.color;
					mp[tmpx][tmpy].index = tmp.index;
					mp[prex][prey].is = 0;
					mp[prex][prey].color = NULL;
					tmp.is = 0;
					tmp.color = NULL;
					initpaint();
					if (judge_general(tmpx, tmpy) == 1)
					{
						beginPaint();
						setTextColor(RED);
						setTextSize(30);
						setTextBkColor(EMPTY);
						paintText(250, 600, "将   军!");
						endPaint();
					}
				}
				else
				{
					beginPaint();
					setTextColor(RED);
					setTextSize(30);
					setTextBkColor(EMPTY);
					paintText(250, 600, "请规范行棋");
					endPaint();
					tmp.is = 0;
					tmp.color = NULL;
				}
			}
			else//格子内没有棋子
			{
				//paint_rect(tmpx, tmpy);
				if (tmp.is == 1)
				{
					if (judge_piece(tmpx, tmpy) == 1)
					{
						q.push_back(mp[tmpx][tmpy]);
						q.push_back(mp[prex][prey]);
						if (q.size() > 6) {
							q.pop_front();
							q.pop_front();
						}
						if (mp[prex][prey].pos == 1)
						{
							mp[prex][prey].pos = 0;
							mp[tmpx][tmpy].pos = 1;
						}
						if (mp[prex][prey].index == 4)//若是黑将移动,黑将位置重新赋值
						{
							black_general_x = tmpx;
							black_general_y = tmpy;
						}
						else if (mp[prex][prey].index == 11)//若是红将移动,红将位置重新赋值
						{
							red_general_x = tmpx;
							red_general_y = tmpy;
						}
						mp[prex][prey].is = 0;
						mp[prex][prey].color = NULL;
						mp[tmpx][tmpy].index = tmp.index;
						mp[tmpx][tmpy].is = tmp.is;
						mp[tmpx][tmpy].color = tmp.color;
						tmp.is = 0;
						tmp.color = NULL;
						initpaint();
						if (judge_general(tmpx, tmpy) == 1)
						{
							beginPaint();
							setTextColor(RED);
							setTextSize(30);
							setTextBkColor(EMPTY);
							paintText(250, 600, "将   军!");
							endPaint();
						}
					}
					else
					{
						beginPaint();
						setTextColor(RED);
						setTextSize(30);
						setTextBkColor(EMPTY);
						paintText(250, 600, "请规范行棋");
						endPaint();
						tmp.is = 0;
						tmp.color = NULL;
					}
					//initpaint();
				}
				else paint_rect(tmpx, tmpy);
				//initpaint();
			}

		}
		if (red_general_isexist == 0)
		{
			beginPaint();
			setTextSize(70);
			setTextColor(BLACK);
			setTextBkColor(RGB(3, 168, 158));
			paintText(130, 270, "黑方获胜");
			endPaint();
		}
		else if (black_general_isexist == 0)
		{
			beginPaint();
			setTextSize(70);
			setTextColor(RED);
			setTextBkColor(RGB(3, 168, 158));
			paintText(130, 270, "红方获胜");
			endPaint();
		}
	}
	else if (button == RIGHT_BUTTON && e == BUTTON_DOWN)
	{
		initpaint();
		tmp.is = 0;
		tmp.color = NULL;

	}

	//initpaint();
}
void paint(piece s)
{
	beginPaint();
	//clearDevice();
	//putImageScale(&chessimg, 0, 0, 650, 701);
	setPenColor(RGB(245, 222, 179));
	setPenWidth(3);
	setBrushColor(RGB(245, 222, 179));
	ellipse(s.x - 20, s.y - 20, s.x + 20, s.y + 20);
	if (s.color == 'B')
		setTextColor(BLACK);
	else setTextColor(RED);
	setTextSize((int)(20 * sin(pi / 4)) * 2);
	setTextBkColor(EMPTY);
	paintText(s.x - (int)(20 * sin(pi / 4)), s.y - (int)(20 * sin(pi / 4)), chessname[s.index]);
	endPaint();
}

void initmp()
{
	for (int a = 0; a < 10; a++)
	{
		for (int b = 0; b < 9; b++)
		{
			mp[a][b].x = INTERVAL + 55 * (b);
			mp[a][b].y = INTERVAL + 55 * (a);
			mp[a][b].color = NULL;
			mp[a][b].index = -1;
			mp[a][b].is = 0;
			mp[a][b].pos = 0;
			mp[a][b].row = a;
			mp[a][b].col = b;
		}
	}
	int j = 0;
	for (int a = 0; a < 5; a++)
	{
		mp[0][a].index = j++;
		mp[0][a].is = 1;
		mp[0][a].color = 'B';
	}
	j = 3;
	for (int a = 5; a < 9; a++)
	{
		mp[0][a].index = j--;
		mp[0][a].is = 1;
		mp[0][a].color = 'B';
	}
	int i = 7;
	for (int a = 0; a < 5; a++)
	{
		mp[9][a].index = i++;
		mp[9][a].is = 1;
		mp[9][a].color = 'R';
	}
	i = 10;
	for (int a = 5; a < 9; a++)
	{
		mp[9][a].index = i--;
		mp[9][a].is = 1;
		mp[9][a].color = 'R';
	}
	mp[2][1].index = 5;
	mp[2][7].index = 5;
	mp[2][1].color = 'B';
	mp[2][7].color = 'B';
	mp[7][1].index = 12;
	mp[7][7].index = 12;
	mp[7][1].color = 'R';
	mp[7][7].color = 'R';
	mp[2][1].is = 1;
	mp[2][7].is = 1;
	mp[7][1].is = 1;
	mp[7][7].is = 1;
	for (int a = 0; a < 9; a += 2)
	{
		mp[3][a].index = 6;
		mp[6][a].index = 13;
		mp[3][a].is = 1;
		mp[6][a].is = 1;
		mp[3][a].color = 'B';
		mp[6][a].color = 'R';
		mp[6][a].pos = 1;
	}
}
void initpaint()
{
	
	
	chessboard();
	for (int a = 0; a < 10; a++)
		for (int b = 0; b < 9; b++)
		{
			if (mp[a][b].is == 1)
			{
				paint(mp[a][b]);
			}
		}
}
void paint_rect(int tmpx, int tmpy)
{
	//initpaint();
	beginPaint();
	setPenColor(RGB(0, 0, 225));
	setBrushColor(EMPTY);
	rectangle(mp[tmpx][tmpy].x - 25, mp[tmpx][tmpy].y - 25, mp[tmpx][tmpy].x + 25, mp[tmpx][tmpy].y + 25);
	endPaint();
}
int judge_piece(int x, int y)//18ma07che5 12pao29xiang3 10shi6 13zu else jiang
{
	if (mp[prex][prey].index == 1 || mp[prex][prey].index == 8)
	{
		if ((x == prex - 2 && y == prey - 1 && mp[prex - 1][prey].is == 0) || (x == prex - 2 && y == prey + 1 && mp[prex - 1][prey].is == 0)
			|| (x == prex - 1 && y == prey + 2 && mp[prex][prey + 1].is == 0) || (x == prex + 1 && y == prey + 2 && mp[prex][prey + 1].is == 0)
			|| (x == prex + 2 && y == prey + 1 && mp[prex + 1][prey].is == 0) || (x == prex + 2 && y == prey - 1 && mp[prex + 1][prey].is == 0)
			|| (x == prex + 1 && y == prey - 2 && mp[prex][prey - 1].is == 0) || (x == prex - 1 && y == prey - 2 && mp[prex][prey - 1].is == 0))
		{
			return 1;
		}
		else return 0;
	}
	else if (mp[prex][prey].index == 0 || mp[prex][prey].index == 7)
	{
		if (prey == y)
		{
			for (int i = min(prex, x) + 1; i < max(prex, x); i++)
			{
				if (mp[i][prey].is == 1)return 0;
			}
			return 1;
		}
		else if (prex == x)
		{
			for (int i = min(prey, y) + 1; i < max(prey, y); i++)
			{
				if (mp[prex][i].is == 1)return 0;
			}
			return 1;
		}
		else return 0;
	}
	else if (mp[prex][prey].index == 5 || mp[prex][prey].index == 12)
	{
		if (mp[x][y].is == 1)
		{
			if (prey == y)
			{
				int ant = 0;
				for (int i = min(prex, x) + 1; i < max(prex, x); i++)
				{
					if (mp[i][prey].is == 1)ant++;
				}
				if (ant == 1)return 1;
				else return 0;
			}
			else if (prex == x)
			{
				int ant = 0;
				for (int i = min(prey, y) + 1; i < max(prey, y); i++)
				{
					if (mp[prex][i].is == 1)ant++;
				}
				if (ant == 1)return 1;
				else return 0;
			}
			else return 0;
		}
		else
		{
			if (prey == y)
			{
				for (int i = min(prex, x) + 1; i < max(prex, x); i++)
				{
					if (mp[i][prey].is == 1)return 0;
				}
				return 1;
			}
			else if (prex == x)
			{
				for (int i = min(prey, y) + 1; i < max(prey, y); i++)
				{
					if (mp[prex][i].is == 1)return 0;
				}
				return 1;
			}
			else return 0;
		}
	}
	else if (mp[prex][prey].index == 2 || mp[prex][prey].index == 9)
	{
		if (prex <= 4)
		{
			if (x <= 4)
			{
				if ((x == prex - 2 && y == prey - 2 && mp[prex - 1][prey - 1].is == 0)
					|| (x == prex - 2 && y == prey + 2 && mp[prex - 1][prey + 1].is == 0)
					|| (x == prex + 2 && y == prey + 2 && mp[prex + 1][prey + 1].is == 0)
					|| (x == prex + 2 && y == prey - 2 && mp[prex + 1][prey - 1].is == 0))
				{
					return 1;
				}
				else return 0;
			}
			else return 0;
		}
		else if (prex >= 5)
		{
			if (x > 4)
			{
				if ((x == prex - 2 && y == prey - 2 && mp[prex - 1][prey - 1].is == 0)
					|| (x == prex - 2 && y == prey + 2 && mp[prex - 1][prey + 1].is == 0)
					|| (x == prex + 2 && y == prey + 2 && mp[prex + 1][prey + 1].is == 0)
					|| (x == prex + 2 && y == prey - 2 && mp[prex + 1][prey - 1].is == 0))
				{
					return 1;
				}
				else return 0;
			}
			else return 0;
		}
	}
	else if (mp[prex][prey].index == 3 || mp[prex][prey].index == 10)
	{
		if (prex <= 4)
		{
			if (x > 2 || y < 3 || y>5)return 0;
			else
			{
				if ((x == prex - 1 && y == prey - 1) || (x == prex - 1 && y == prey + 1)
					|| (x == prex + 1 && y == prey + 1) || (x == prex + 1 && y == prey - 1))
				{
					return 1;
				}
				else return 0;
			}
		}
		else
		{
			if (x < 7 || y < 3 || y>5)return 0;
			else
			{
				if ((x == prex - 1 && y == prey - 1) || (x == prex - 1 && y == prey + 1)
					|| (x == prex + 1 && y == prey + 1) || (x == prex + 1 && y == prey - 1))
				{
					return 1;
				}
				else return 0;
			}
		}
	}
	else if (mp[prex][prey].index == 6 || mp[prex][prey].index == 13)
	{
		if (mp[prex][prey].pos == 0)//北卒
		{
			if (prex <= 4)
			{
				if ((x == prex + 1) && (y == prey))return 1;
				else return 0;
			}
			else
			{
				if (((x == prex + 1) && (y == prey)) || ((x == prex) && (y = prey - 1)) || ((x == prex) && (y = prey + 1)))return 1;
				else return 0;
			}
		}
		else//南兵
		{
			if (prex >= 5)
			{
				if ((x == prex - 1) && (y == prey)) { return 1; }
				else return 0;
			}
			else
			{
				if (((x == prex - 1) && (y == prey)) || ((x == prex) && (y = prey - 1)) || ((x == prex) && (y = prey + 1))) {
					return 1;
				}
				else return 0;
			}
		}
	}
	else
	{
		//int ant = 0;
		if (prex <= 4)
		{
			int ant = 0;
			for (int i = prex + 1; i <= 9; i++)
			{
				if (mp[i][prey].index == 4 || mp[i][prey].index == 11)break;
				if (mp[i][prey].is == 1)ant++;
			}
			if (ant == 0)return 1;
		}
		else
		{
			int ant = 0;
			for (int i = prex - 1; i >= 0; i--)
			{
				if (mp[i][prey].index == 4 || mp[i][prey].index == 11)break;
				if (mp[i][prey].is == 1)ant++;
			}
			if (ant == 0)return 1;
		}
		if (mp[prex][prey].pos == 0)
		{
			if (((x == prex) && (y == prey + 1)) || ((x == prex) && (y == prey - 1)) || ((y == prey) && (x == prex - 1)) || ((y == prey) && (x == prex + 1)))
			{
				return 1;
			}
			else return 0;
		}
		else
		{
			if (((x == prex) && (y == prey + 1)) || ((x == prex) && (y == prey - 1)) || ((y == prey) && (x == prex - 1)) || ((y == prey) && (x == prex + 1)))
			{
				return 1;
			}
			else return 0;

		}
	}
	//return 1;
}
void chessboard()
{
	beginPaint();
	clearDevice();
	setPenColor(RED);
	setPenWidth(1);
	for (int a = 0; a <= 9; a++)
	{
		line(INTERVAL, INTERVAL + a * 55, INTERVAL + 440, INTERVAL + a * 55);
	}
	for (int a = 0; a <= 8; a++)
	{
		line(INTERVAL + a * 55, INTERVAL, INTERVAL + a * 55, INTERVAL + 495);
	}
	line(INTERVAL + 3 * 55, INTERVAL, INTERVAL + 5 * 55, INTERVAL + 2 * 55);
	line(INTERVAL + 5 * 55, INTERVAL, INTERVAL + 3 * 55, INTERVAL + 2 * 55);
	line(INTERVAL + 3 * 55, INTERVAL + 7 * 55, INTERVAL + 5 * 55, INTERVAL + 9 * 55);
	line(INTERVAL + 5 * 55, INTERVAL + 7 * 55, INTERVAL + 3 * 55, INTERVAL + 9 * 55);
	setBrushColor(EMPTY);
	rectangle(INTERVAL - 5, INTERVAL - 5, INTERVAL + 5 + 440, INTERVAL + 5 + 495);
	setBrushColor(WHITE);
	rectangle(INTERVAL, INTERVAL + 220, INTERVAL + 440 + 1, INTERVAL + 275 + 1);
	setTextColor(BLACK);
	setTextFont("楷体");
	setTextSize(30);
	setTextBkColor(WHITE);
	paintText(INTERVAL + 73, INTERVAL + 235, "楚河           汉界");
	setTextBkColor(RGB(218, 112, 214));
	setTextSize(50);
	paintText(INTERVAL + 8 * 55 + 33, INTERVAL + 55, "悔棋");
	endPaint();

}
int judge_general(int x, int y)//判断是否被将军
{
	if (mp[x][y].index == 1 || mp[x][y].index == 8)
	{
		if (mp[x][y].color == 'B')
		{
			if ((red_general_x == x - 2 && red_general_y == y - 1) || (red_general_x == x - 2 && red_general_y == y + 1)
				|| (red_general_x == x - 1 && red_general_y == y + 2) || (red_general_x == x + 1 && red_general_y == y + 2)
				|| (red_general_x == x + 2 && red_general_y == y + 1) || (red_general_x == x + 2 && red_general_y == y - 1)
				|| (red_general_x == x + 1 && red_general_y == y - 2) || (red_general_x == x - 1 && red_general_y == y - 2))
			{
				return 1;
			}
			else return 0;
		}
		else
		{
			if ((black_general_x == x - 2 && black_general_y == y - 1) || (black_general_x == x - 2 && black_general_y == y + 1)
				|| (black_general_x == x - 1 && black_general_y == y + 2) || (black_general_x == x + 1 && black_general_y == y + 2)
				|| (black_general_x == x + 2 && black_general_y == y + 1) || (black_general_x == x + 2 && black_general_y == y - 1)
				|| (black_general_x == x + 1 && black_general_y == y - 2) || (black_general_x == x - 1 && black_general_y == y - 2))
			{
				return 1;
			}
			else return 0;
		}
	}
	else if (mp[x][y].index == 0 || mp[x][y].index == 7)
	{
		if (mp[x][y].color == 'B')
		{
			if (red_general_y == y)
			{
				for (int i = min(red_general_x, x) + 1; i < max(red_general_x, x); i++)
				{
					if (mp[i][red_general_y].is == 1)return 0;
				}
				return 1;
			}
			else if (red_general_x == x)
			{
				for (int i = min(red_general_y, y) + 1; i < max(red_general_y, y); i++)
				{
					if (mp[red_general_x][i].is == 1)return 0;
				}
				return 1;
			}
			else return 0;
		}
		else
		{
			if (black_general_y == y)
			{
				for (int i = min(black_general_x, x) + 1; i < max(black_general_x, x); i++)
				{
					if (mp[i][black_general_y].is == 1)return 0;
				}
				return 1;
			}
			else if (black_general_x == x)
			{
				for (int i = min(black_general_y, y) + 1; i < max(black_general_y, y); i++)
				{
					if (mp[black_general_x][i].is == 1)return 0;
				}
				return 1;
			}
			else return 0;
		}
	}
	else if (mp[x][y].index == 5 || mp[x][y].index == 12)
	{
		if (mp[x][y].color == 'B')
		{
			if (red_general_y == y)
			{
				int ant = 0;
				for (int i = min(red_general_x, x) + 1; i < max(red_general_x, x); i++)
				{
					if (mp[i][red_general_y].is == 1)ant++;
				}
				if (ant == 1)return 1;
				else return 0;
			}
			else if (red_general_x == x)
			{
				int ant = 0;
				for (int i = min(red_general_y, y) + 1; i < max(red_general_y, y); i++)
				{
					if (mp[red_general_x][i].is == 1)ant++;
				}
				if (ant == 1)return 1;
				else return 0;
			}
			else return 0;
		}
		else
		{
			if (black_general_y == y)
			{
				int ant = 0;
				for (int i = min(black_general_x, x) + 1; i < max(black_general_x, x); i++)
				{
					if (mp[i][black_general_y].is == 1)ant++;
				}
				if (ant == 1)return 1;
				else return 0;
			}
			else if (black_general_x == x)
			{
				int ant = 0;
				for (int i = min(black_general_y, y) + 1; i < max(black_general_y, y); i++)
				{
					if (mp[black_general_x][i].is == 1)ant++;
				}
				if (ant == 1)return 1;
				else return 0;
			}
			else return 0;
		}
		return  0;
	}
	else if (mp[x][y].index == 6 || mp[x][y].index == 13)
	{
		if (mp[x][y].color == 'B')
		{
			if ((red_general_x == x + 1 && red_general_y == y) || (red_general_x == x && red_general_y == y - 1)
				|| (red_general_x == x && red_general_y == y + 1))
			{
				return 1;
			}
			else return 0;
		}
		else
		{
			if ((black_general_x == x - 1 && black_general_y == y) || (black_general_x == x && black_general_y == y - 1)
				|| (black_general_x == x && black_general_y == y + 1))
			{
				return 1;
			}
			else return 0;
		}
	}
}

以上就是C/C++实现经典象棋游戏的示例代码的详细内容,更多关于C++象棋游戏的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C/C++实现经典象棋游戏的示例代码

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C语言实现经典小游戏井字棋的示例代码

这个三子棋游戏是在学习C语言的过程中自己编写的一个小游戏,现在将自己的思路(主要以流程图形式和代码中的注释表达)和具体代码以及运行结果分享出来以供大家学习参考,希望对大家有所帮助
2022-11-13

C语言实现经典windows游戏扫雷的示例代码

今天我们会用C语言实现一个经典的windows小游戏:扫雷。扫雷是一款单机小游戏,每次通关最高难度的关卡都会开心好一阵。现在学会了C语言,总算可以自己实现扫雷了。话不多说,咱们开始吧
2022-11-13

C语言实现经典扫雷小游戏的示例代码

扫雷游戏是在一个指定的二维空间里,随机布置雷,把不是雷的位置都找出来,在你点一个位置的时候它会显示它周围全部雷的个数,根据这个线索去找,会更容易赢。本文将用C语言实现这一经典游戏,感兴趣的可以尝试一下
2022-11-13

C语言实现三子棋游戏的示例代码

今天我们将会用C语言实现三子棋。所谓三子棋,就是三行三列的棋盘,玩家可以和电脑下棋,率先连成三个的获胜。话不多说,我们开始吧
2022-11-13

C语言实现三子棋小游戏的示例代码

这篇文章主要介绍了如何通过C语言实现三子棋小游戏,三子棋小游戏的实现主要依赖于循环语句、函数和数组,感兴趣的小伙伴可以尝试一下
2022-11-13

100行C#代码实现经典扫雷游戏

这篇文章主要为大家详细介绍了如何用100行C#代码实现经典的扫雷游戏,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以参考一下
2023-02-27

基于C语言实现钻石棋游戏的示例代码

独立钻石是源于18世纪法国的宫廷贵族的自我挑战类单人棋游戏,可以锻炼逻辑思维能力。本文将用C语言实现这一简单的游戏,感兴趣的小伙伴可以了解一下
2023-02-26

C#实现经典飞行棋游戏的脚本怎么写

今天小编给大家分享一下C#实现经典飞行棋游戏的脚本怎么写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。效果展示主函数
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录