Problem 1490 五子棋

Time Limit: 1000 mSec

Memory Limit : 32768 KB

 Problem Description

五子棋是起源于中国古代的传统黑白棋种之一。现代五子棋日文称之为"连珠",音译为"Renju",英文称之为"Gobang"或"FIR"(Five in a Row的缩写),亦有"连五子"、"五子连"、"串珠"、"五目"、"五目碰"、"五格"等多种称谓。其规则简单,在15*15的棋盘上黑棋先行,其中一方有五枚棋子连成一线即可获胜(这里不考虑专业比赛中的禁手等规则)。

不过在很多情况下,当一方出现“活四”,就是四子连在一起,并且两端都可以再放一粒己方的棋子的时候,对方就会主动认输(如图中10,6,12,14)。

五子棋中通常用字母和数字的组合表示棋子的位置,如上图A1表示左下角的点。

请编写一个程序判断在一个给定的五子棋对局中的胜方。

 Input

本题有多组输入数据,你必须处理到EOF为止。

每组数据有若干行,落子位置由若干空格或换行隔开,由黑方开始,双方轮流下子。最后以END表示棋局结束。我们保证输入的是一个合法的棋局,并且恰好在棋谱的最后一步落子时分出胜负,只有在一方有五枚棋子连成一线或者出现“活四”的情况下才分出胜负。

 Output

输出只有一行,表示胜方和总共落子的步数,中间用一个空格隔开,B表示黑方胜,W表示白方胜。

 Sample Input

F7 F8 G6 E8 D8 H5 E5 G8 H8 H6 I5 H4 I7 H3 END

 Sample Output

W 14

 Hint

每行表示的落子数不一定相同。

以为要用搜索做,想了半天,,我滴神,,凭落子总数就可判断谁胜谁负,当输入结束表明已经分出胜负,而总棋数总是奇偶徘徊,黑方先下,如果总期数是奇数那么就是黑方赢了,反之,白方赢。。

#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int num=0;
char a[10];
while(~scanf("%s",a))
{
if(a[0]=='E'&&a[1]=='N')
{
if(num%2)
printf("B %d\n",num);
else
printf("W %d\n",num);
num=0;
}
else
num++;
}
return 0;
}

最新文章

  1. 用Bitbucket搭建博客初探
  2. 20145206邹京儒《Java程序设计》第4周学习总结
  3. Android自动化测试 - 自动化测试工具比较
  4. Bolts-Android
  5. AngularJS学习小结
  6. 实验一DOS报告
  7. About JavaScript
  8. SDUT 最短路径(二维SPFA)
  9. Python之路: 面向对象
  10. MySQL数据库需进行修改密码问题解决方案
  11. ubuntu下截图工具推荐 -- [deepin-scrot]
  12. C语言判断文件夹或者文件是否存在的方法【转】
  13. Java反射1——扫描某个包下的所有类
  14. javascript 全选 反选 js代码
  15. 检查许可证所需的adobe application manager 丢失或损坏
  16. Scrum立会报告+燃尽图(十月十七日总第八次)
  17. u-boot界面添加命令[demo]
  18. Ubuntu下编译C语言程序(同时给编译生成的文件命名)
  19. The Definitive Guide To Django 2 学习笔记(七) 第四章 模板 (三)使用模板系统
  20. poj 1028 Web Navigation

热门文章

  1. MongoDB管理练习
  2. mysql安装及基本概念
  3. DHCP server工作原理
  4. Python 语言规范
  5. 2019年今日头条机试_JAVA后台岗_第二题
  6. Java面试题之HashSet 的实现原理?
  7. this.treeData = JSON.parse(JSON.stringify(this.d)) 树的序列化反序列化
  8. 搜索 || DFS || POJ 1321 棋盘问题
  9. python爬虫---从零开始(三)Requests库
  10. git-忽略文件改动不进行提交