#include<iostream>
#include<iomanip>
using namespace std; const int X = ; //棋盘行数
const int Y = ; //棋盘列数
char p[X][Y]; //定义棋盘
int m = ;//定义临时点,保存输入坐标
int n = ; void display() //输出棋盘
{
for (int i = ; i < X; i++)
cout << setw() << setfill(' ') << i;
cout << endl;
for ( int i = ; i < Y; i++)
{
cout << setw() << setfill(' ') << i;
for (int j = ; j < X; j++)
cout << setw() << setfill(' ') << p[i][j];
cout << endl;
} } void black() //黑方落子
{
cout << "请黑方输入落子位置:\n"
<< "请输入落子的行数:";
cin >> m;
cout << "请输入落子的列数:";
cin >> n;
if (m <= || m >= X || n >= Y || n <= )
{
cout << "超出棋盘范围,请重新输入正确坐标!\n";
black();
}
else if ((p[m][n] == ) || p[m][n] == )
{
cout << "该点已有棋子,请重新选取落子点!\n";
black();
}
else
p[m][n] = ; //黑方用1来表示
system("cls");
display();
} void red() //红方落子
{
cout << "请红方输入落子位置:\n"
<< "请输入落子的行数:";
cin >> m;
cout << "请输入落子的列数:";
cin >> n;
if (m >= X || m <= || n <= || n >= Y)
{
cout << "超出棋盘范围,请重新输入正确坐标!\n";
red();
}
else if ((p[m][n] == ) || p[m][n] == )
{
cout << "该点已有棋子,请重新选取落子点!\n";
red();
}
else
p[m][n] = ; //红方用2来表示
system("cls");
display();
} int evalue() //只需要判断落子点为中心的九点“米”字是否连续即可
{
int k = , r = ;
/*斜线判断*/
for (k = ; k < X - ; k++) //两条,其中的p[k][r]!='-'是排除空子的情况
{
for (r = ; r < Y - ; r++)
{
if (p[k][r] != '-'&&p[k - ][r - ] == p[k][r]
&&p[k - ][r - ] == p[k][r] && p[k + ][r + ] == p[k][r]
&&p[k + ][r + ] == p[k][r])
return ;
else if (p[k][r] != '-'&&p[k + ][r - ] == p[k][r]
&& p[k + ][r - ] == p[k][r]
&& p[k - ][r + ] == p[k][r] && p[k - ][r + ] == p[k][r])
return ;
}
}
/*横线判断*/
for (k = ; k < X; k++) //p[k][r]!='-'是排除空子的情况
for (r = ; r < Y - ; r++)
if (p[k][r] != '-'&&p[k][r - ] == p[k][r]
&& p[k][r - ] == p[k][r]
&& p[k][r + ] == p[k][r] && p[k][r + ] == p[k][r])
return ;
/*竖线判断*/
for (k = ; k < X - ; k++) //p[k][r]!='-'是排除空子的情况
for (r = ; r < Y; r++)
if (p[k][r] != '-'&&p[k - ][r] == p[k][r]
&& p[k - ][r] == p[k][r]
&& p[k + ][r] == p[k][r] && p[k + ][r] == p[k][r])
return ;
return ;
} int main()
{
memset(p, '-', ); //初始化为‘-’
cout << "欢迎使用简易双人对战五子棋游戏\n"
<< "五子棋棋谱如下:\n";
display();
while ()
{
red();
if (evalue())
{
cout << "红方赢!\n";
break;
}
black();
if (evalue())
{
cout << "黑方赢!\n";
break;
}
}
return ;
}

小知识解释:

setw和setfill函数(#include<iomanip>)

setw(n)使得输出结果右对齐,左边默认用空格填充,若设置了setfill,则用setfill里面的字符来填充。

如果输出选项少于n,则填充,否则不会填充,自然输出。相关代码解释见"C++小知识积累"

[收藏]C++简单五子棋的更多相关文章

  1. 简单五子棋,没有电脑AI

    刚学了C#委托,做了个五子棋练习,把前台绘制和后台逻辑分开,前台绘制方法用委托传给后台逻辑. 界面好简单... 先看类图 控制类控制整个游戏的逻辑,包括调用棋盘类的属性初始化棋盘.初始化两个棋手.轮流 ...

  2. 用Java写的简单五子棋游戏(原创五子连珠算法)

    源码jar包(已安装jdk环境可直接运行) 下载地址:http://download.csdn.net/detail/eguid_1/9532912 五子连珠算法为自创算法,对于五子棋该算法性能足以. ...

  3. C++的简单“五子棋”游戏,只是核心代码,资源代码未添加

    ChessBoard.h #ifndef __CHESS_BOARD_H__ #define __CHESS_BOARD_H__ #include "DataStruct.h" # ...

  4. Leo-io 的C语言实现简单五子棋游戏观后感

    源代码: /************************************************************** ** 文 件 名:wuziqi.cpp ** 功    能:扫 ...

  5. C++ 之 简单的五子棋AI程序

    本人是大一新生,寒假无聊,抱着试试看的心态(没有想到可以完成),写了C++的简单五子棋程序,开心.     下面是效果图:     一.首先讲讲大致思路.            五子棋实现的基础:  ...

  6. angular实现了一个简单demo,angular-weibo-favorites

    前面必须说一段 帮客户做了一个过渡期的项目,唯一的要求就是速度,我只是会点儿基础的php,于是就用tp帮客户做了这个项目.最近和客户架构沟通,后期想把项目重新做一下,就用现在最流行的技术,暂时想的使用 ...

  7. 基于redis分布式缓存实现

    Redis的复制功能是完全建立在之前我们讨论过的基 于内存快照的持久化策略基础上的,也就是说无论你的持久化策略选择的是什么,只要用到了Redis的复制功能,就一定会有内存快照发生,那么首先要注意你 的 ...

  8. Js仿弹框

    收藏一个简单实用的JS弹框,通过隐藏和显示div来实现,代码来自脚本之家! <html> <head> <title> LIGHTBOX EXAMPLE </ ...

  9. 涂鸦之作WanAndroid第三方APP

    Wan Android App Introduction 我的涂鸦之作,正如名字一样 这个一个WanAndroid 的第三方Android客户端,采用MVP架构+Kotlin语言+一大堆轮子.现在的代 ...

随机推荐

  1. go:结构体的可访问性

    1.要使某个符号对其他包( package)可见(即可以访问),需要将该符号定义为以大写字母开头------摘自go相关书籍2.go只限制包内外的可访问性,而不限制同包内不同文件的可访问性 本文讨论结 ...

  2. C# 使用AForge调用笔记本摄像头拍照

    vs2012  winform 连接摄像头设备,这里需要引入 代码: using AForge; using AForge.Controls; using AForge.Imaging; using ...

  3. linux部署pxe+kickstart批量安装linux操作系统

    环境 系统 centos6.6 无图形界面 ip 192.168.2.1 系统 centos7.2 有图形界面 以下命令在centos6.6上执行 1. yum -y install dhcp* tf ...

  4. October 27th Week 44th Thursday 2016

    The art of being wise is the art of knowing what to overlook. 智慧之道在于懂得该忽略什么. Always do your best. Wh ...

  5. Delphi编程时候诡异地出现ORA-00937错误,记录解决它的思路和方法

    首先需要说明,这个问题的出现需要几个前提:使用微软的Oracle驱动(使用Oracle自己的驱动不会出现这个问题).使用绑定变量法,使用Format等方式拼接SQL也不会出现这个问题,还有一些诡异的规 ...

  6. SQL 谜题(父亲的邮票)

    问题:父亲需要些1分,2分,3分,5分,10分的邮票, 其中两种各买四张,另外的三种各买三张 我忘记是哪几种了?他给了我一些10分硬币,金额刚好买这些邮票 计算及分析过程: --通过极限算法,若都是3 ...

  7. 桥接模式/bridge模式/对象结构型

    意图 将抽象部分与它的实现部分分离,使它们都可以独立的变化. 动机 当一个抽象类有多个实现时,通常用继承来协调它们.但是继承机制将抽象和实现固定,难以对抽象部分和实现部分独立地进行修改.扩充和重用. ...

  8. gitbook安装与使用之windows下搭建gitbook平台

    最近需要在GitBook中去阅读电子书 安装nodejs cnpm安装gitbook 解压书籍文件,并cd到书籍文件目录 gitbook serve 浏览器访问localhost:4000 先在win ...

  9. python strip()函数 介绍

    python strip()函数 介绍,需要的朋友可以参考一下   函数原型 声明:s为字符串,rm为要删除的字符序列 s.strip(rm)        删除s字符串中开头.结尾处,位于 rm删除 ...

  10. Python中的生成器与yield

    对于python中的yield有些疑惑,然后在StackOverflow上看到了一篇回答,所以搬运过来了,英文好的直接看原文吧. 可迭代对象 当你创建一个列表的时候,你可以一个接一个地读取其中的项.一 ...