C++实现简单的五子棋程序





//全部代码12 .26.2017

#include<iostream>
#include<stdlib.h>
#include<iomanip>     //格式化输出
using namespace std;
const int N = 9;       //修饰N为常量
static int A=0, B=0;
char command;


class jiemian
{
public:


void Jiemainbuzhi();
void initBoard();
void Qijubuzhi();
void Chesspainter(int x,int y);
int check(int x, int y);
int checkcommand(int x, int y);
void  chessicont(int x);
int Checkzuobiao(int i, int j, char flag);
int x, y;    //设置路障
protected:

bool flag = 0;      //下棋次数计数
char  chessBord[N + 1][N + 1];
};


void jiemian::chessicont(int x)
{
if (x == 1)
A++;
if (x == 2)
B++;
cout << "A : B —" << A << ":" << B << '\t';
}


void jiemian::Jiemainbuzhi()
{
cout << "————五子棋游戏————ZXL" << endl;
cout << "################################" << endl;
cout << "#     1.进入游戏   E           # " << endl;
cout << "#     2.退出游戏   0 0         # " << endl;
cout << "#     3.选择关卡   C           # " << endl;        
cout << "################################" << endl;
}


void jiemian::Qijubuzhi()
{
cout << "plaese entry — x — y " << endl;
cout << setw(3) << setfill(' ') << left << 0;
for (int i = 1; i < N + 1; i++) {
cout << setw(6) << setfill(' ') << right << i;
}
cout << endl;
cout << "   |";
for (int i = 1; i < N + 1; i++) {
cout << "-----|";
}
cout << endl;
for (int i = 1; i < N + 1; i++) {
for (int j = 0; j < N + 1; j++) {
if (j == 0) {
cout << setw(3) << setfill(' ') << left << i << '|';
}
else {
cout << "  " << chessBord[i][j] << "  |";
}
}
cout << endl;
cout << "   |";
for (int i = 1; i < N + 1; i++) {
cout << "-----|";
}
cout << endl;
}
}


void jiemian::initBoard()
{
for (int i = 0; i < N + 1; i++)
for (int j = 0; j < N + 1; j++)
{
chessBord[i][j] = ' ';     //初始化
}
}


void  jiemian::Chesspainter(int x, int y)    //下棋
{


if (-1 == check(x, y))
{
cout << "坐标请输入棋盘之间的数"<<endl;
}
else if (0 == check(x, y))
{
cout << "坐标已经输入过,请不要重复输入" << endl;
}
else
{
system("CLS");
if (flag == 0)
{
chessBord[x][y] = 'x';
cout << "Palyer " << "A with 'x' IS " << "X ," << x << "Y ," << y << endl;
flag = 1;
}
else if (flag == 1)
{
chessBord[x][y] = 'o';
cout << "Palyer " << "B with 'o' IS " << "X ," << x << "Y ," << y << endl;
flag = 0;
}
Qijubuzhi();
}
}


int  jiemian::checkcommand(int x,int y)    //缺少容错机制
{
if(0==x&&0==y)
{
return 1;
}
else
return 0;
}


int  jiemian::check(int x, int y)
{
if (x > N + 1 || y > N + 1 || x < 1 || y < 1)
{
return -1;
}
if (chessBord[x][y] != ' ')
{
return 0;
}
return 1;
}


int  jiemian::Checkzuobiao(int i,int j ,char flag)  //入参坐标和选手的旗子
{
int x = i, y = j;
int begin = 0;  
int end = 0;

    int begin1 = 0;
int end1 = 0;

//判断列是否满足条件  hao
(i - 4) > 0 ? begin = i - 4 : begin = 1; //已经将列减4 或者从边界算
(i + 4) < N ? end = N : end = (i + 4);


for (j, i = begin; i + 4 <= end; i++)
{
if (chessBord[i][j] == flag&&chessBord[i + 1][j] == flag&&chessBord[i + 2][j] == flag&&chessBord[i + 3][j] == flag&&chessBord[i + 4][j] == flag)
{
return 1;
}
}

//判断行是否满足条件 hao
i = x, j = y;
(j - 4) > 0 ? begin = j - 4 : begin = 1;  //已经将横坐标减4
(j + 4) < N ? end = N : end = (j + 4); //如果末尾大于N则,从N算最后一个


for (i, j = begin; j + 4 <= end; j++)
{
if (chessBord[i][j] == flag&&chessBord[i][j + 1] == flag&&chessBord[i][j + 2] == flag&&chessBord[i][j + 3] == flag&&chessBord[i][j + 4] == flag)
{
return 1;
}
}




//判断正对角线是否满足 HAO
int len = 0;
i = x, j = y;
i >j ? len = j - 1 : len = i - 1;   //判断i>j的作用,按照离边距小的坐标减做初始值
if (len > 4)
len = 4;
begin = i - len;       //横坐标的起始位置
begin1 = j - len;      //纵坐标,,因为是正斜边所以两边要减相同数


i > j ? len = (N - i) : len = (N - j);   //结束坐标也要按照距离边界近的点去减
if (len>4)
len = 4;
end= i + len;       //横坐标的结束位置
end1 = j + len;      //纵坐标的结束位置


for (int i = begin, j = begin1; (i + 4 < end) && (j + 4 < end1); i++, j++)
{
if (chessBord[i][j] == flag&&chessBord[i + 1][j + 1] == flag&&chessBord[i + 2][j + 2] == flag&&chessBord[i + 3][j + 3] == flag&&chessBord[i + 4][j + 4] == flag)
{
return 1;
}
}


//判断负对角线是否满足 HAO
i = x, j = y;
(i - 1) >(N - j) ? len = (N - j) : len = i - 1;  //判断负对角线坐标的位置是否在上下减小的距离
if (len > 4)
len = 4;
begin = i - len;       //横坐标的起始位置
begin1 = j + len;      //纵坐标的起始位置


(N - i) > (j - 1) ? len = (j - 1) : len = (N - i);
if (len>4)
len = 4;
end = i + len;       //横坐标的结束位置
end1 = j - len;      //纵坐标的结束位置


for (int i = begin, j = begin1; (i + 4 < end) && (j - 4 > end1); i++, j--)
{
if (chessBord[i][j] == flag&&chessBord[i + 1][j - 1] == flag&&chessBord[i + 2][j - 2] == flag&&chessBord[i + 3][j - 3] == flag&&chessBord[i + 4][j - 4] == flag)
{
return 1;
}
}

//判断棋盘是否下满 .ZUIHOU
for (int z = 1; z < N + 1; z++)           //棋盘有没有下满
{
for (int l = 1; l < N + 1; l++)
{
if (chessBord[z][l] == ' ')
return -1;      //说明棋盘中还有空格


}
}


return 0;
}






int main()
{
jiemian obj;
obj.Jiemainbuzhi();
while(1)
{
int x=0, y=0;
char flager;
cout << "请输入命令 —";
cin >> command;
if ('E' == command)
{
system("CLS");
obj.initBoard();
obj.Qijubuzhi();
while ('E' == command)
{
cout << "请输入坐标";
cin >> x >> y;
if (1 == obj.checkcommand(x, y))
{
break;
}
obj.Chesspainter(x, y);

if (0 == obj.Checkzuobiao(x, y, ' '))     //判断棋盘是否下满HAO
{
cout << "DRAW: againt ?  Y  OR  N  " << endl;
cin >> flager;
if (flager == 'N')
{
break;
}
else
{
system("CLS");
obj.initBoard();
}
}
if (1== obj.Checkzuobiao(x, y,'x')|| 1== obj.Checkzuobiao(x, y, 'o'))
{
if (1 == obj.Checkzuobiao(x, y, 'x'))
{
obj.chessicont(1);     //显示比分
cout << "   A IS WIN" << endl;
}
    if (1 == obj.Checkzuobiao(x, y, 'o'))
{
obj.chessicont(2);
cout << "   B IS WIN" << endl;
}
cout << "againt ?  Y  OR  N  " << endl;
cin >> flager;
if (flager == 'N')
{
break;
}
else
{
obj.initBoard();
}
}
}
}
else if ('C' == command)
{
system("CLS");
cout << "please waitting___" << endl;
}
else
{
system("CLS");
cout << "请输入正确的命令" << endl;
obj.Jiemainbuzhi();
}


}
}


  • 17
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值