POJ 1568 Find the Winning Move(极大极小搜索)
题目链接:http://poj.org/problem?id=1568
题意:给出一个4*4的棋盘,x和o两人轮流放。先放够连续四个的赢。给定一个局面,下一个轮到x放。问x是否有必胜策略?若有,输出能够赢的最小的坐标?
思路:(1)Maxfind(Min):每次放x,若得到的Max大于等于Min,则直接返回Max。因为Minfind要用这个Max更新Min,若x放置之后能够得到一个比Min大的,显然这样放最好;因为Min无法用Max更新;
(2)Minfind(Max)类似;
(3)因此,枚举第一个人放的位置,Minfind,返回的是INF则胜利。
char s[10][10];
int ansX,ansY,chessCnt;
int isOver(int x,int y)
{
int r[4]={0},c[4]={0},i,j;
clr(r,0); clr(c,0);
FOR0(i,4) FOR0(j,4)
{
if(s[i][j]=='x') r[i]++,c[j]++;
if(s[i][j]=='o') r[i]--,c[j]--;
}
if(abs(r[x])==4||abs(c[y])==4) return 1;
int cnt1=0,cnt2=0;
FOR0(i,4)
{
if(s[i][i]=='x') cnt1++;
if(s[i][3-i]=='x') cnt2++;
if(s[i][i]=='o') cnt1--;
if(s[i][3-i]=='o') cnt2--;
}
if(abs(cnt1)==4&&x==y||abs(cnt2)==4&&x+y==3) return 1;
return 0;
}
int Minfind(int,int,int);
int Maxfind(int x,int y,int Min)
{
int temp,Max=-INF,i,j;
if(isOver(x,y)) return Max;
if(chessCnt==16) return 0;
FOR0(i,4) FOR0(j,4) if(s[i][j]=='.')
{
s[i][j]='x';
chessCnt++;
temp=Minfind(i,j,Max);
chessCnt--;
s[i][j]='.';
if(temp>Max) Max=temp;
if(Max>=Min) return Max;
}
return Max;
}
int Minfind(int x,int y,int Max)
{
int temp,Min=INF,i,j;
if(isOver(x,y)) return Min;
if(chessCnt==16) return 0;
FOR0(i,4) FOR0(j,4) if(s[i][j]=='.')
{
s[i][j]='o';
chessCnt++;
temp=Maxfind(i,j,Min);
chessCnt--;
s[i][j]='.';
if(temp<Min) Min=temp;
if(Min<=Max) return Min;
}
return Min;
}
int check()
{
int Max=-INF,i,j,temp;
FOR0(i,4) FOR0(j,4) if(s[i][j]=='.')
{
s[i][j]='x';
chessCnt++;
temp=Minfind(i,j,Max);
chessCnt--;
s[i][j]='.';
if(temp>Max) Max=temp,ansX=i,ansY=j;
if(Max==INF) return 1;
}
return 0;
}
int main()
{
char op[5];
while(scanf("%s",op)&&op[0]!='$')
{
int i,j;
chessCnt=0;
FOR0(i,4)
{
RD(s[i]);
FOR0(j,4) chessCnt+=s[i][j]!='.';
}
if(chessCnt<=4||!check()) puts("#####");
else printf("(%d,%d)\n",ansX,ansY);
}
}
POJ 1568 Find the Winning Move(极大极小搜索)的更多相关文章
- poj 1568 Find the Winning Move 极大极小搜索
思路:用极大极小搜索解决这样的问题很方便!! 代码如下: #include <cstdio> #include <algorithm> #define inf 10000000 ...
- POJ 1568 Find the Winning Move
Find the Winning Move 链接 题意: 4*4的棋盘,给出一个初始局面,问先手有没有必胜策略? 有的话输出第一步下在哪里,如果有多个,按(0, 0), (0, 1), (0, 2), ...
- poj1568 Find the Winning Move[极大极小搜索+alpha-beta剪枝]
Find the Winning Move Time Limit: 3000MS Memory Limit: 32768K Total Submissions: 1286 Accepted: ...
- POJ 1568 极大极小搜索 + alpha-beta剪枝
极小极大搜索 的个人理解(alpha-beta剪枝) 主要算法依据就是根据极大极小搜索实现的. 苦逼的是,查了两个晚上的错,原来最终是判断函数写错了..瞬间吐血! ps. 据说加一句 if sum & ...
- 【迭代博弈+搜索+剪枝】poj-1568--Find the Winning Move
poj 1568:Find the Winning Move [迭代博弈+搜索+剪枝] 题面省略... Input The input contains one or more test cas ...
- 算法笔记--极大极小搜索及alpha-beta剪枝
参考1:https://www.zhihu.com/question/27221568 参考2:https://blog.csdn.net/hzk_cpp/article/details/792757 ...
- 【poj1568】 Find the Winning Move
http://poj.org/problem?id=1568 (题目链接) 题意 两人下4*4的井字棋,给出一个残局,问是否有先手必胜策略. Solution 极大极小搜索.. 这里有个强力优化,若已 ...
- 极大极小搜索思想+(α/β)减枝 【转自-----https://blog.csdn.net/hzk_cpp/article/details/79275772】
极大极小搜索,即minimax搜索算法,专门用来做博弈论的问题的暴力. 多被称为对抗搜索算法. 这个搜索算法的基本思想就是分两层,一层是先手,记为a,还有一层是后手,记为b. 这个搜索是认为这a与b的 ...
- [CodeVs3196]黄金宝藏(DP/极大极小搜索)
题目大意:给出n(≤500)个数,两个人轮流取数,每次可以从数列左边或者右边取一个数,直到所有的数被取完,两个人都以最优策略取数,求最后两人所得分数. 显然这种类型的博弈题,第一眼就是极大极小搜索+记 ...
随机推荐
- 2014 ACM/ICPC Asia Regional Guangzhou Online
Wang Xifeng's Little Plot http://acm.hdu.edu.cn/showproblem.php?pid=5024 预处理出每个点八个方向能走的最远距离,然后枚举起点,枚 ...
- IE8下jQuery改变png图片透明度时出现的黑边问题
png24格式的图片在用jQuery添加显示隐藏动画时发现,图片的半透明区域出现黑边? 在网上搜了搜主要有以下几种办法: 1.把图片保存成PNG-8格式. 2.把背景色一起切入并保存为JPG格式. 以 ...
- UglifyJS--javascript代码压缩使用指南{转}
在线测试地址 http://lisperator.net/uglifyjs/下面都是基于linux系统的安装使用.UglifyJS是遵循了CommonJS规范写成的,可以在支持CommonJS模块系统 ...
- 用vs2010 编写C语言程序,VS2010 C++编译报错LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏
编译mongodb-src-r2.2.2出现以下问题 LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏 这个是由于日志文件引起的,可以将 项目\ ...
- Chapter 4 持久存储数据对象
1.使用with open("filename.扩展名","r/w/rb/wb") as data代替data=open(..);data.close() 打开 ...
- HDU 4027 Can you answer these queries?(线段树,区间更新,区间查询)
题目 线段树 简单题意: 区间(单点?)更新,区间求和 更新是区间内的数开根号并向下取整 这道题不用延迟操作 //注意: //1:查询时的区间端点可能前面的比后面的大: //2:优化:因为每次更新都 ...
- 替代jquery
如果不需要过多操作,不引用jquery 1.document.ready :$(function(){}) http://www.cnblogs.com/a546558309/p/3478344.ht ...
- GCD初步认识
//(1)用异步函数往并发队列中添加任务, //总结:同时开启三个子线程 - (void)test1 { //1.获得全局的并发队列 dispatch_queue_t queue = dispatch ...
- JS获取Url参数的通用方法
//获取URL中的参数 function request(paras) { var url = location.href.replace('#', ''); var paraString = url ...
- 在Vista或Windows 7系统上安装Sharepoint 2007
在Vista或Windows 7系统上安装Sharepoint 2007 2010-03-05 18:53:19| 分类: 技术文章|字号 订阅 SharePoint 2007 不能直接安装 ...