winform 五子棋 判断输赢 分类: WinForm 2014-08-07 20:55 256人阅读 评论(0) 收藏
新手上路,高手勿进!
利用数组,根据新旧数组值的不同,获取那个点是什么棋子;
说明:
棋盘:15*15;
定义4个全局变量:
string[,] stroldlist = new string[15, 15];//初始的List
public string[,] strlist = new string[15, 15]; //0 :未下,1:黑子 2:白子
int icount = 0;//五子连线算赢
string abc = "";//获取是白子还是黑子,1=黑子 2=白子 0=无子
自我感觉这种方法好笨,但是实在想不到什么好方法了。
代码如下:
#region 判断输赢
public void
PanDuan() {
//赋值
for (int i = 0; i < 225; i++) {
strlist[i / 15, i % 15] = sandwich[i].btn.Text;
if (stroldlist[i / 15, i % 15] != strlist[i / 15, i % 15]) {
stroldlist[i / 15, i % 15] = strlist[i / 15, i % 15];//把新数组赋值给旧数组
icount = i;
abc = strlist[i / 15, i % 15];
}
}
//检查输赢,共有四中情况,横、竖、左斜、右斜
int ix = icount / 15;//X轴
int iy = icount % 15;//y轴
// PublicClass.ShowMessage(ix+"--------"+iy);
int count = 0;//五个点相连为赢
// int kstart = 0;//五子连开始的点
//四种情况,横、竖、左斜、右斜
//横(左上角坐标为0,0) "|"
int k_shu_min = ix - 4 < 0 ? 0 : ix - 4;
int k_shu_max = ix + 4 < 15 ? ix + 4 : 14;
for (int k = k_shu_min; k <= k_shu_max; k++) {
if (strlist[k, iy] == abc) {
count++;
if (count >= 5) {
if (abc == "1") {
PublicClass.ShowMessage("黑子胜!");
}
if (abc == "2") {
PublicClass.ShowMessage("白子胜!");
}
return;
}
}else {
count = 0;
}
}
count = 0;//count值清0
//竖 "一"
int k_heng_min = iy - 4 < 0 ? 0 : iy - 4;
int k_heng_max = iy + 4 < 15 ? iy + 4 : 14;
for (int k = k_heng_min; k <= k_heng_max; k++) {
if (strlist[ix, k] == abc) {
count++;
if (count >= 5) {
if (abc == "1") {
PublicClass.ShowMessage("黑子胜!");
}
if (abc == "2") {
PublicClass.ShowMessage("白子胜!");
}
return;
}
}else {
count = 0;
}
}
count = 0;
//左斜 "/"
int k_left_min = ix - 4 < 0 ? 0 : ix - 4;
int k_left_max = ix + 4 < 15 ? ix + 4 : 14;
for (int k = k_left_min; k <= k_left_max; k++) {
int ky = 0;
if (ix + iy > 14) {
ky = ix + iy - k >= 14 ? 14 : ix + iy - k;
} else {
ky = ix + iy - k <= 0 ? 0 : ix + iy - k;
}
if (strlist[k, ky] == abc) {
count++;
if (count >= 5) {
if (abc == "1") {
PublicClass.ShowMessage("黑子胜!");
}
if (abc == "2") {
PublicClass.ShowMessage("白子胜!");
}
return;
}
}else {
count = 0;
}
}
count = 0;
//右斜 "\"
int k_right_min = iy - 4 < 0 ? 0 : iy - 4;
int k_right_max = iy + 4 < 15 ? iy + 4 : 14;
for (int k = k_right_min; k <= k_right_max; k++) {
int kx = 0;
if (ix < iy) {
kx = ix - iy + k <= 0 ? 0 : ix - iy + k;
} else {
kx = ix - iy + k >= 14 ? 14 : ix - iy + k;
}
// PublicClass.ShowMessage(kx+"---"+k);
if (strlist[kx, k] == abc) {
count++;
if (count >= 5) {
if (abc == "1") {
PublicClass.ShowMessage("黑子胜!");
}
if (abc == "2") {
PublicClass.ShowMessage("白子胜!");
}
return;
}
}else {
count = 0;
}
}
count = 0;
}
#endregion
版权声明:本文为博主原创文章,未经博主允许不得转载。
winform 五子棋 判断输赢 分类: WinForm 2014-08-07 20:55 256人阅读 评论(0) 收藏的更多相关文章
- hadoop调优之一:概述 分类: A1_HADOOP B3_LINUX 2015-03-13 20:51 395人阅读 评论(0) 收藏
hadoop集群性能低下的常见原因 (一)硬件环境 1.CPU/内存不足,或未充分利用 2.网络原因 3.磁盘原因 (二)map任务原因 1.输入文件中小文件过多,导致多次启动和停止JVM进程.可以设 ...
- bzoj 1041 圆上的整点 分类: Brush Mode 2014-11-11 20:15 80人阅读 评论(0) 收藏
这里先只考虑x,y都大于0的情况 如果x^2+y^2=r^2,则(r-x)(r+x)=y*y 令d=gcd(r-x,r+x),r-x=d*u^2,r+x=d*v^2,显然有gcd(u,v)=1且u&l ...
- ios UIKit动力 分类: ios技术 2015-07-14 12:55 196人阅读 评论(0) 收藏
UIkit动力学是UIkit框架中模拟真实世界的一些特性. UIDynamicAnimator 主要有UIDynamicAnimator类,通过这个类中的不同行为来实现一些动态特性. 它一般有两种初始 ...
- iOS调用相机,相册,上传头像 分类: ios技术 2015-04-14 11:23 256人阅读 评论(0) 收藏
一.新建工程 二.拖控件,创建映射 三.在.h中加入delegate @interface ViewController : UIViewController 复制代码 四.实现按钮事件 -(IBAc ...
- Bzoj 1036 树的统计 分类: ACM TYPE 2014-12-29 18:55 72人阅读 评论(0) 收藏
Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. Q ...
- HTTP 错误 500.19- Internal Server Error 错误解决方法 分类: Windows服务器配置 2015-01-08 20:16 131人阅读 评论(0) 收藏
1.第一种情况如下: 解决方法如下: 经过检查发现是由于先安装Framework组件,后安装iis的缘故,只需重新注册下Framework就可以了,具体步骤如下 1 打开运行,输入cmd进入到命令提示 ...
- Ubuntu 命令行下快速打开各类文件 分类: ubuntu shell 2014-11-18 20:06 210人阅读 评论(0) 收藏
xdg-open 命令可以用来在Ubuntu下快速打开各类文件. 下面是从 manual 文档里截取的内容: 可以知道,该命令的功能是在图形界面下按照用户的平时习惯打开各类文件,甚至是链接. 这样,我 ...
- Can you find it? 分类: 二分查找 2015-06-10 19:55 5人阅读 评论(0) 收藏
Description Give you three sequences of numbers A, B, C, then we give you a number X. Now you need t ...
- House Robber 分类: leetcode 算法 2015-07-09 20:53 2人阅读 评论(0) 收藏
DP 对于第i个状态(房子),有两种选择:偷(rob).不偷(not rob) 递推公式为: f(i)=max⎧⎩⎨⎪⎪{f(i−1)+vali,f(i−2)+vali,robi−1==0robi−1 ...
随机推荐
- 《cut命令》-linux命令五分钟系列之十九
本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket. 为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. ...
- ES6-个人学习笔记一--let和const
es6已经推出一段时间了,虽然在兼容和应用上还有不少的难题,但是其提供的未来前端代码编程的发展趋势和一些好用的功能还是很吸引人的,因此个人买了'阮一峰'先生的es6入门,希望对其有一个了解和学习,本系 ...
- js学习--DOM操作详解大全二(window对象)
一.window - 计时器 1、setTimeout()可以用来在指定的时间之后单次调用函数.setTimeount(f,1000);//一秒后调用函数fclearTimeout();取消函数的执行 ...
- ThinkPHP Uploadify 图片上载
从官方网站下载的Uploadify最新版本:http://www.uploadify.com/download/ jQuery库是1.7.1版本. 下载好的Uploadify目录下面的文件有: 用到的 ...
- TCP/IP笔记 应用层(2)——FTP
1. FTP(File Transfer Protocol) 文件传送协议 FTP 只提供文件传送的一些基本的服务,它使用 TCP 可靠的运输服务.FTP 的主要功能是减少或消除在不同操作系统下处理文 ...
- auto_ptr, which can release the space automatically
C++的auto_ptr所做的事情,就是动态分配对象以及当对象不再需要时自动执行清理. 使用std::auto_ptr,要#include <memory>.[1] 中文名 自动指针 外 ...
- C# Json反序列化处理
最近换工作了 从客户端转到Web端 第一个任务就是去别人的页面上抓取数据 用到的是JSON 因为他们网站json的格式有点怪 所以 就在JSON反序列化上面 花了一点时间 首先用到的工具是http:/ ...
- CALayer 为什么选择 cg 开头 而 不选择 UI 开头
CALayer 的属性 为什么选择 cg 开头 而 不选择 UI 开头 , 也就是说 为啥要选择 比如 .CGColor 等
- PANGU---Planet and Asteroid Natural scene Generation Utility
PANGU是由英国dundee邓迪大学开发的一款行星.小行星自然环境仿真软件 https://www.star-dundee.com/products/pangu-planet-and-asteroi ...
- Hive的MoveTask错误
最近在部署Hive上线,结果在线上线下同时出现了MoveTask报错的现象,虽然两者错误的日志以及错误信息一样,但是经过分析解决又发现两者的原因是不一样的. 首先线下的错误日志: 2015-05-18 ...