简易五子棋 V1.1.0
main.cpp
#include "fivechess.cpp" int main()
{
fivechess a;
a.RunGame();
getchar();
return 0;
}
fivechess.h
#include <conio.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <string>
#include <windows.h> using namespace std;
const int MAX_SIZE=15; struct point
{
int cursor_x,cursor_y;
};
void gotoxy(int x,int y)//位置函数
{
COORD pos;
pos.X=x;
pos.Y=y;
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE),pos);
}
void color(int a)//颜色函数
{
SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),a);
} class fivechess
{
public:
void RunGame();
private:
void init();
void print_chess();
string getstyle(int ,int );
bool move_cursor();
int who_win(int x,int y); // 返回 0代表没有人胜利,如果为1 则黑子胜利,2则为白棋;
void change_chessboard();
void change_chess();
void show_winnwer();
int chessboard[MAX_SIZE][MAX_SIZE];
int count;
int winner;
point now,pre;
char opt;
};
fivechess.cpp
#include "fivechess.h"
void fivechess::RunGame()
{
init();
system("title 简易五子棋 ——ACM制作");//设置标题
system("mode con cols=63 lines=33");//设置窗口大小
system("color E0");//设置颜色
print_chess();
while(1)
{
if(move_cursor())
{
change_chess();
winner=who_win(now.cursor_x,now.cursor_y);
}
change_chessboard();
pre.cursor_x=now.cursor_x,pre.cursor_y=now.cursor_y;
if(winner)
{
show_winnwer();
break;
}
}
}
/********************************************/
void fivechess::change_chess()
{
int x,y;
x=now.cursor_x*2+1,y=now.cursor_y*2+1;
count++;
chessboard[now.cursor_x][now.cursor_y]=!(count%2)+1;
gotoxy(y*2,x);
if(count%2==1) cout<<"●";
else cout<<"○";
gotoxy(0,30); }
void fivechess::show_winnwer()
{
gotoxy(25,14);
if(winner==1)cout<<"黑棋获胜";
else if(winner==2) cout<<"白棋获胜";
else cout<<" 平 局 ";
gotoxy(0,30);
}
void fivechess::change_chessboard()
{
int x,y;
int xx,yy;
xx=pre.cursor_x*2+1,yy=pre.cursor_y*2+1;
x=now.cursor_x*2+1,y=now.cursor_y*2+1;
gotoxy(yy*2-2,xx-1);
cout<<" ";
gotoxy(yy*2+2,xx-1);
cout<<" ";
gotoxy(yy*2-2,xx+1);
cout<<" ";
gotoxy(yy*2+2,xx+1);
cout<<" "; gotoxy(y*2-2,x-1);
cout<<"┏";
gotoxy(y*2+2,x-1);
cout<<"┓";
gotoxy(y*2-2,x+1);
cout<<"┗";
gotoxy(y*2+2,x+1);
cout<<"┘";
gotoxy(0,30);
}
int fivechess::who_win(int x,int y)
{
int i,z28,z46,z19,z73;
int wanjia=!(count%2)+1;
z28=z46=z19=z73=1; for(i=1; i<5; i++) if(y+1<15&&chessboard[x][y+i]==wanjia) z46++;
else break; // 横着是否有五子连珠
for(i=1; i<5; i++) if(y-1>=0&&chessboard[x][y-i]==wanjia) z46++;
else break; for(i=1; i<5; i++) if(x+1<15&&chessboard[x+i][y]==wanjia) z28++;
else break;
for(i=1; i<5; i++) if(x-1>=0&&chessboard[x-i][y]==wanjia) z28++;
else break; for(i=1; i<5; i++) if(x+1<15&&y+1<15&&chessboard[x+i][y+i]==wanjia) z73++;
else break;
for(i=1; i<5; i++) if(x-1>=0&&y-1>=0&&chessboard[x-i][y-i]==wanjia) z73++;
else break; for(i=1; i<5; i++) if(x+1<15&&y-1>=0&&chessboard[x+i][y-i]==wanjia) z19++;
else break;
for(i=1; i<5; i++) if(y+1<15&&x-1>=0&&chessboard[x-i][y+i]==wanjia) z19++;
else break; if(z28>=5||z46>=5||z19>=5||z73>=5) return wanjia;
else
{
if(count==15*15) return 3;
return 0;
}
} bool fivechess::move_cursor() // 输入操作
{
opt=_getch();
if(opt=='2'&&now.cursor_x!=14) now.cursor_x++;
else if(opt=='8'&&now.cursor_x!=0) now.cursor_x--;
else if(opt=='4'&&now.cursor_y!=0) now.cursor_y--;
else if(opt=='6'&&now.cursor_y!=14) now.cursor_y++;
else if(opt=='~') exit(0);
else if(opt=='5')
{
if(chessboard[now.cursor_x][now.cursor_y]==0) return true;
else return false;
}
return false;
}
void fivechess::init() // 初始化所有信息
{
int i,j;
for(i=0; i<MAX_SIZE; i++)
{
for(j=0; j<MAX_SIZE; j++)
chessboard[i][j]=0;
}
count=0;
winner=0;
now.cursor_x=now.cursor_y=7;
pre.cursor_x=pre.cursor_y=7;
}
string fivechess::getstyle(int i,int j)//获得棋盘中指定坐标交点位置的字符,通过制表符拼成棋盘
{
if(chessboard[j][i]==1)//1为黑子
return "●";
else if(chessboard[j][i]==2)//2为白子
return "○";
else if(i==0&&j==0)//以下为边缘棋盘样式
return "┏";
else if(i==MAX_SIZE-1&&j==0)
return "┓";
else if(i==MAX_SIZE-1&&j==MAX_SIZE-1)
return "┛";
else if(i==0&&j==MAX_SIZE-1)
return "┗";
else if(i==0)
return "┣";
else if(i==MAX_SIZE-1)
return "┫";
else if(j==0)
return "┯";
else if(j==MAX_SIZE-1)
return "┷";
return "╋";//中间的空位
}
void fivechess::print_chess()
{
system("cls");
int MAXSIZE=MAX_SIZE*2+1;
int i,j,x,y;
x=now.cursor_x*2+1,y=now.cursor_y*2+1;
for(i=0; i<MAXSIZE; i++)
{
for(j=0; j<MAXSIZE; j++)
{
if(i%2==1&&j%2==1)
{
cout<<getstyle(j/2,i/2);
}
else if(i%2==0&&j%2==0)
{
if(i+1==x&&j+1==y) cout<<"┏";
else if(i-1==x&&j+1==y) cout<<"└";
else if(i-1==x&&j-1==y) cout<<"┘";
else if(i+1==x&&j-1==y) cout<<"┐";
else cout<<" ";
}
else if(i==0||i==MAX_SIZE*2||j==0||j==MAX_SIZE*2) cout<<" ";
else if(i%2==1&&j%2==0&&i!=0&&i!=MAX_SIZE*2&&j!=0&&j!=MAX_SIZE*2)
{
cout<<"━";
}
else if(i%2==0&&j%2==1&&i!=0&&i!=MAX_SIZE*2&&j!=0&&j!=MAX_SIZE*2)
{
cout<<"│";
}
else cout<<" ";
}
printf("\n");
}
}
简易五子棋 V1.1.0的更多相关文章
- FineUI(专业版)v1.2.0 和 FineUI(开源版)v4.1.1 同时发布!
FineUI(开源版)v4.1.1 (建议所有 v4.x 升级到此版本):http://fineui.com/demo/ +2014-08-15 v4.1.1 -修正Form中表单字段设 ...
- RapidJSON v1.1.0 发布简介
时隔 15.6 个月,终于发布了一个新版本 v1.1.0. 新版本除了包含了这些日子收集到的无数的小改进及 bug fixes,也有一些新功能.本文尝试从使用者的角度,简单介绍一下这些功能和沿由. P ...
- 读阿里巴巴Java开发手册v1.2.0之工程结构有感【架构篇】
首先,把昨天那俩条sql语句的优化原因给大家补充一下,第一条效率极低,第二条优化后的,sql语句截图如下: 经过几个高手的评论和个人的分析: 第一条sql语句查询很慢是因为它首先使用了in关键字查询, ...
- 读阿里巴巴Java开发手册v1.2.0之编程规约有感【架构篇】
不为过去蹉跎,改变当下. 为什么开篇就送这么一句话给大家,我相信很多处于1-3年码龄的哥们儿们,在平时的编码历程中编码的个性可能是多彩的,每个人都有每个人特定的风格,但是我们现在这么随意写,以后这么 ...
- 阿里官方Java代码规范标准《阿里巴巴Java开发手册 终极版 v1.3.0》
终极版 v1.3.0 2017年开春之际,阿里诚意献上重磅大礼:<阿里巴巴Java开发手册>,首次公开阿里官方Java代码规范标准.这套Java统一规范标准将有助于提高行业编码规范化水平, ...
- 浏览器端类EXCEL表格插件 版本更新 - 智表ZCELL产品V1.1.0.1版本发布
智表(ZCELL),浏览器下纯JS表格控件,为您提供EXCEL般的智能体验! 纯国产化.高性价比的可靠解决方案. 更新说明 让大家久等了.因为最近忙其他项目,发布时间稍有延迟. 下次版本更新 ...
- 智表ZCELL产品V1.4.0开发API接口文档 与 产品功能清单
为了方便大家使用ZCELL,应网友要求,整理编写了相关文档,现与产品一起同步发布,供大家下载使用,使用过程中如有疑问,请与我QQ联系. 智表(ZCELL)V1.4.0版本 功能清单文档下载地址: 功 ...
- kubernetes之Kubeadm快速安装v1.12.0版
通过Kubeadm只需几条命令即起一个单机版kubernetes集群系统,而后快速上手k8s.在kubeadm中,需手动安装Docker和kubeket服务,Docker运行容器引擎,kubelet是 ...
- 【开源】SpringBootNetty聊天室V1.2.0升级版本介绍
前言 SpringBoot!微服务微架构的基础,Netty通信框架的元老级别框架,即之前的SpringBoot与Netty的实现聊天室的功能后已经过了不到一周的时间啦,今天我们更新了项目版本从V1.0 ...
随机推荐
- thinkphp框架做项目的前期配置
ThinkPHP 目录结构说明 ThinkPHP.php:框架的公共入口文件 App:项目放置目录 Common:包含框架的一些公共文件.系统定义.系统函数和惯例配置等 Lang:系统语言文件目录 L ...
- android 完美退出应用程序。
Android 程序在点击回退键时,如果只有一个activity,调用finish()方法就能退出界面,如果有多个界面,在调用该方法时,只会销毁当前的activity,显示栈顶的其它activity, ...
- 有向图tarjan算法求连通分量的粗浅讲解、证明, // hdu1269
打算开始重新复习一遍相关算法.对于有向图tarjan算法,通过学习过很多说法,结合自己的理解,下面给出算法自己的观点. 算法总模型是一个dfs,结合一个stack(存放当前尚未形成SCC的点集合),记 ...
- hdu3491最小割转最大流+拆点
题意:求最小割,即求最大流即可.此题之关键为拆点(限制在点),每条边都是双向边,注意一下. 未1A原因:在拆点之后添加边的过程中,要注意,出去的是i`,进来的是i,!!所以,写addegde函数时候 ...
- CentOS 7.5 初始网络配置
最近刚装完 CentOS 7.5 系统,由于网络不通,导致无法用 yum 命令下载软件,经过了各种折腾,终于搞定了,这里讲解一下 如何设置初始网络. 本案例环境 VmWare 11.0 , 操作系统 ...
- codevs——1842 递归第一次
1842 递归第一次 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题解 题目描述 Description 同学们在做题时常遇到这种函数 f( ...
- python入门示例程序
该实例是raspi和dsp电机运动控制板的串口uart通信: import serial class SerialHandler(): ''' raspi serial for communicati ...
- Spring 详解(三)------- SpringMVC拦截器使用
目录 不拦截静态资源 使用拦截器 拦截器使用测试 SimpleMappingExceptionResolver 拦截异常 不拦截静态资源 如果配置拦截类似于*.do格式的拦截规则,则对静态资源的访问是 ...
- 2019年春招Android方向腾讯电话面试
第一问:TCP与UDP的区别 参考答案: 1.基于连接与无连接 2.TCP要求系统资源较多,UDP较少: 3.UDP程序结构较简单 4.流模式(TCP)与数据报模式(UDP); 5.TCP保证数据正确 ...
- Effective Java P2 Item1 Consider static factory methods instead of constructors
获得一个类的实例的传统方法是公共的构造方法,还可以提供一个公共的静态工厂方法(一个返回值为该类实例的简单静态方法), 例如Boolean(boolean 的封装类) public static Boo ...