ZUFEOJ 2395 天棋哥哥大战AlphGo
Description
3月15日,人机围棋大战巅峰对决在韩国首尔落下帷幕。五番棋的最后一局中,韩国著名棋手李世乭尽管与人工智能“AlphaGo”缠斗至官子阶段,但在双双进入读秒后最终还是投子认输,以总比分1∶4结束了这场举世瞩目的人机大战。
100年后的某一天,天棋哥哥为了给李世乭报仇,挽回人类尊严,代表人类向AlphaGo发起了挑战。
100年后的AlphaGo比现在强了几百倍,谷歌公司允许天棋哥哥携带一个程序与AlphaGo对战。
为了能战胜AlphaGo,现在请你帮助天棋哥哥写一个程序来判断他这一步落子后,最多能提几子。
提子规则如下:
中国围棋棋盘可以看做一个19*19的网格,每一个网格都可以下棋子。
【棋子的气】
一个棋子在棋盘上,与它直线紧邻的空点是这个棋子的“气”。
直线紧邻的点上如果有同色棋子存在,这些棋子就相互连接成一个不可分割的整体。
直线紧邻的点上如果有异色棋子存在,此处的气便不存在。棋子如失去所有的气,就不能在棋盘上存在。
【提子】
把无气之子清理出棋盘的手段叫“提子”。提子有二种:
1、下子后,对方棋子无气,应立即提取对方无气之子。
2、下子后,双方棋子都呈无气状态,应立即提取对方无气之子。
现在,给出一个局面,轮到天棋哥哥下,请计算他落子后最多能提多少子。
Input
每组测试数据19行,每行为长度19的字符串
'.'代表空格,'X'代表天棋哥哥,'O’代表AlphaGo
Output
输出一个数字,代表最多能提几子。
Sample Input
...................
....XX.............
...XOOX............
.....X.............
....X..............
.....O.............
......O............
...................
...................
...................
...................
...................
...................
...................
...................
...................
...................
...................
...................
...................
....XX.............
...XO.X............
.....X.............
....X..............
.....O.............
......O............
...................
...................
...................
..................X
.................XO
..................O
..................X
...................
...................
...................
...................
...................
Sample Output
2
2
#include<iostream>
#include<stdio.h>
#include<cstring>
#include<queue>
#include<algorithm>
using namespace std;
char a[][];
int res,res1,sum;
int rx[]={,,,-};
int ry[]={,-,,};
bool vis[][];
bool flag1;
bool check(int x,int y)//检查.是不是在O旁边
{
int xx,yy;
bool flag=false;
for(int i=;i<;i++)
{
xx=x+rx[i];
yy=y+ry[i];
if(xx>=&&xx<&&yy>=&&yy<)
if(a[xx][yy]=='O')
{
flag=true;
break;
}
}
return flag;
}
void dfs(int x,int y)
{
int xx,yy;
for(int i=;i<;i++)
{
xx=x+rx[i];
yy=y+ry[i];
if(xx>=&&xx<&&yy>=&&yy<)
{
if(a[xx][yy]=='.')
{
flag1=false;
}
if(a[xx][yy]=='O'&&!vis[xx][yy])
{
vis[xx][yy]=true;
sum++;
dfs(xx,yy);
}
}
}
}
int check2()//判断能提几个子
{
int i,j;
res1=;//每次放子能提多少子
for(i=;i<;i++)
for(j=;j<;j++)
if(a[i][j]=='O'&&!vis[i][j])
{
vis[i][j]=true;
flag1=true;
sum=;//sum是每一块能提的子
dfs(i,j);
if(flag1)res1+=sum;
}
return res1;
}
int main()
{
int i,j;
while(scanf("%s",&a[])!=EOF)
{
res=;
int res1;
int n,m;
for(i=;i<;i++)
for(j=;j<;j++)
cin>>a[i][j]; for(i=;i<;i++)
for(j=;j<;j++)
if(a[i][j]=='.'&&check(i,j))
{
a[i][j]='X';
memset(vis,false,sizeof(vis));
res1=check2();
if(res1>res) res=res1; a[i][j]='.';
}
cout<<res<<endl;
}
return ;
}
ZUFEOJ 2395 天棋哥哥大战AlphGo的更多相关文章
- 天棋哥哥大战AlphaGo
天棋哥哥大战AlphaGo Time Limit: 1 Sec Memory Limit: 128 MB Submit: 20 Solved: 9 [Submit][Status][Web Boa ...
- 随便谈谈alphago与人机大战
3月16日历时8天的人机大战终于落下帷幕,alphago以4:1的比分击败了当年如日中天的李世石.这个结果让我这个围棋爱好者+计算机爱好者百感交集…… ——一个时代落幕了,一个新的时代开启了. 这次人 ...
- 圣魔大战3(Castle Fantisia)艾伦希亚战记完美攻略
作为城堡幻想曲系列续作,艾伦希亚战记继承了前作的战棋+养成模式进行游戏. (城堡幻想曲3,纠正大家个错误哦,不是圣魔大战3,圣魔大战是城堡幻想曲2,圣魔大战不是个系列,艾伦西亚战记==艾伦希亚战记,一 ...
- 攻略三战的完美体验3Castle Fantisia阿兰·梅希亚战争艾伦西战记它包含重做版本(这是新的艾伦·梅希亚大战)
(城堡幻想曲3,纠正大家个错误哦,不是圣魔大战3,圣魔大战是城堡幻想曲2,圣魔大战不是个系列,艾伦西亚战记==艾伦希亚战记,一个游戏日文名:タイトル キャッスルファンタジア -エレンシア戦記-リニュー ...
- 完美攻略心得之圣魔大战3(Castle Fantisia)艾伦希亚战记(艾伦西亚战记)包含重做版(即新艾伦希亚战记)
(城堡幻想曲3,纠正大家个错误哦,不是圣魔大战3,圣魔大战是城堡幻想曲2,圣魔大战不是个系列,艾伦西亚战记==艾伦希亚战记,一个游戏日文名:タイトル キャッスルファンタジア -エレンシア戦記-リニュー ...
- Unity2017五子棋大战_人机_双人_UNET联网
五子棋大战源码工程基于Unity2017.2进行开发,分为人机.双人.UNET网络三种对战方式,配有案例讲解视频, 其中人机五子棋AI有三种开发难度,欢迎有兴趣的同学加入学习! . 目录 000-展示 ...
- 人机大战中AlphaGo及其执子人黄士杰
2016年3月9日注定要写入围棋界的历史.IT界的历史以及科学界的历史.当天,韩国著名围棋棋手李世石VS谷歌AlphaGo的人机大战赛在韩国首尔举行.对弈的一方为拥有1200多个处理器的谷歌人工智能系 ...
- 【Web前端Talk】无聊吗?写个【飞机大战】来玩吧(上篇)
01前言介绍 微信小游戏是基于微信客户端的游戏,它即点即玩,无需下载安装,体验轻便,可以和微信内的好友一起玩,比如PK.围观等,享受小游戏带来的乐趣.那如何开发一款属于自己的小游戏呢? 源码地址: h ...
- 3D坦克大战游戏源码
3D坦克大战游戏源码,该游戏是基于xcode 4.3,ios sdk 5.1开发.在xcode4.3.3上完美无报错.兼容ios4.3-ios6.0 ,一款ios平台上难得的3D坦克大战游戏源码,有2 ...
随机推荐
- C#调用百度地图API
1.打开链接http://developer.baidu.com/map/jshome.htm这里有很多DEMO,或者你直接百度搜索"百度地图API",第一个就是.进入后有很多方向 ...
- (三)Python在windows上安装
1.安装2.7--进入python官网(网址百度)下载python2.7 和python3.6(很小,2个程序后缀不一样?)2.安装到c:\python----next----advanced不动-- ...
- kinect1在ros-indigo环境配置
根据周大神前车,向git下载驱动里面有详细的安装说明 $ cd $ git clone https://github.com/ZXWBOT/kinect_driver.git 按照安装说明三个包安装成 ...
- centos下安装Jenkins轻松搞定
jenkins安装步骤如下: 命令:yum -y list java* yum -y install java-1.7.0-openjdk.x86_64 ...
- StringBuilder跟StringBuffer
一直以来只知道StringBuffer是线程安全的,StringBuilder是线程不安全的, 所以通常情况下使用StringBuilder,这样可以提升效率!!! 今天由于想起StringBuild ...
- 让webstorm支持新建.vue文件
1. 首先安装vue插件,安装方法: file-->setting --> plugin ,点击plugin,在内容部分的左侧输入框不用输入任何东西,直接点击下图中的按钮. 如下图所 ...
- PAT乙级1034. 有理数四则运算(20)
本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照“a1/b1 a2/b2”的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前,分 ...
- bzoj3156防御准备
3156: 防御准备 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1349 Solved: 605[Submit][Status][Discuss ...
- iOS 8 AutoLayout与Size Class自悟(转载)
iOS 8 AutoLayout与Size Class自悟 Size classiOS 8 AutoLayout 前言 iOS8 和iPhone6发布已经过去蛮久了,广大的果粉终于迎来了大屏iPhon ...
- 使用$_SERVER['HTTP_HOST']时需注意的
在php中,我们一般通过$_SERVER['HTTP_HOST']来活得URL中网站的域名或者ip地址. $_SERVER['HTTP_HOST']在客户的环境里,取得的值总是程序所在的服务器在其局域 ...