HDU 5754 Life Winner Bo(各类博弈大杂合)

时间:2022-06-23 11:26:48

http://acm.hdu.edu.cn/showproblem.php?pid=5754

题意:

给一个国际象棋的棋盘,起点为(1,1),终点为(n,m),现在每个棋子只能往右下方走,并且有4种不同的棋子,棋子的走法与国际象棋走法一致。问最后谁能取得胜利。

思路:

首先推荐一个博客http://www.matrix67.com/blog/archives/6784,这里面对这问题有很好的讲解。

我还是简单解释一下:

①king:

国王每次只能横、竖、斜走一格,这个很好分析,(x,y)如果连个都是奇数,那肯定是必败状态,否则就是必胜状态。

②rook:

车每次能横、竖走任意格,这个问题的模型其实和拿石子是一样的,是个尼姆博弈,有两堆石子,每次可以选择在任意一堆中拿走任意数量的石子,那么这里车的坐标(x,y)就对应了两堆石子的石子数量。如果x=y,那么先手无论拿多少,另一个人总可以在另一堆石子中拿相同的石子数,这样到最后肯定是先手败,如果x!=y则是先手必胜。

③kight:

骑士的走法是先往一个方向走2格,再往其垂直方向走1格。首先通过方程求解的话可以得出(n+m-2)必须得是3的倍数,否则就是平局。如果n=m,那么先手无论怎么操作,另一个人都可以走相反的方向,这样每轮过后棋子的x,y值始终是相等的,此时先手必败。如果n=m+1,或者m+1,此时先手可以一步使得棋子坐标x,y值相等,这就和上一种情况一样了,此时先手必胜。除此之外的情况都是平局,因为玩家可以乱走,使得最后无法到达终点。

④queen:

皇后能横、竖、斜走任意格,这就相当于有两个石子堆,每次可以在任意一堆中拿走任意的石子数量或者在两个堆中拿走相同数量的石子数。这就是一个明显的威佐夫博弈,直接套用黄金分割定律。

 #include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<vector>
#include<stack>
#include<queue>
#include<cmath>
#include<map>
#include<set>
using namespace std;
typedef long long ll;
typedef pair<int,int> pll;
const int INF = 0x3f3f3f3f;
const int maxn=+; int type,n,m; int main()
{
//freopen("in.txt","r",stdin);
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&type,&n,&m);
if(type==)
{
if((n&) && (m&)) puts("G");
else puts("B");
}
else if(type==)
{
if(n==m) puts("G");
else puts("B");
}
else if(type==)
{
if((n+m-)%==)
{
if(n<m) swap(n,m);
if(n==m) puts("G");
else if(n-m==) puts("B");
else puts("D");
}
else puts("D");
}
else
{
if(n==m) puts("B");
else
{
if(n>m) swap(n,m);
n--;m--;
int w=(int)(((sqrt()+)/2.0)*(m-n));
if(w==n) puts("G");
else puts("B");
}
}
}
return ;
}

HDU 5754 Life Winner Bo(各类博弈大杂合)的更多相关文章

  1. HDU 5754 Life Winner Bo (博弈)

    Life Winner Bo 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5754 Description Bo is a "Life W ...

  2. HDU 5754 Life Winner Bo 组合博弈

    Life Winner Bo Problem Description   Bo is a "Life Winner".He likes playing chessboard gam ...

  3. HDU 5754 Life Winner Bo &lpar;各种博弈&rpar; 2016杭电多校联合第三场

    题目:传送门 题意:一个国际象棋棋盘,有四种棋子,从(n,m)走到(1,1),走到(1,1)的人赢,先手赢输出B,后手赢输出G,平局输出D. 题解:先把从(n,m)走到(1,1)看做是从(1,1)走到 ...

  4. HDU 5754 Life Winner Bo &lpar;找规律and博弈&rpar;

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5754 给你四种棋子,棋子一开始在(1,1)点,两个人B和G轮流按每种棋子的规则挪动棋子,棋子只能往右下 ...

  5. 【博弈论】HDU 5754 Life Winner Bo

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5754 题目大意: 4种棋子,象棋中的 1王,2车,3马,4后,选其一,B和G轮流走,不能往左上走,一 ...

  6. HDU 5754 Life Winner Bo

    四种棋子实质上都是一样的思路: 如果某位置的棋子,它下一步可以走到的位置中 能找到有后手胜的位置,那么该位置先手必胜. 如果某位置的棋子,它下一步可以走到的位置中 全是先手胜,那么该位置后手必胜. 其 ...

  7. hdu 5754 Life Winner Bo 博弈论

    对于king:我是套了一个表. 如果起点是P的话,则是后手赢,否则前手赢. 车:也是画图推出来的. 马:也是推出来的,情况如图咯. 对于后:比赛时竟然推错了.QAQ最后看了题解:是个威佐夫博奕.(2, ...

  8. HDU5754 Life Winner Bo(博弈)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5754 Description Bo is a "Life Winner" ...

  9. hdu-5754 Life Winner Bo&lpar;博弈&rpar;

    题目链接: Life Winner Bo Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 131072/131072 K (Java/ ...

随机推荐

  1. Shiro - 限制并发人数登录与剔除

    import org.apache.shiro.cache.Cache; import org.apache.shiro.cache.CacheManager; import org.apache.s ...

  2. Hibernate检索策略之延迟加载和立即加载

    延迟加载:延迟加载(lazy load懒加载)是当在真正需要数据时,才执行SQL语句进行查询.避免了无谓的性能开销. 延迟加载分类:  1.类级别的查询策略 2.一对多和多对多关联的查询策略 3.多对 ...

  3. point&bsol;polyline&bsol;polygon的转化(转)

    首先你要明白Polyline是由path对象构成,Polygon是由ring对象构成,因此实现polyline向polygon的转换,思路如下:1.提取polyline中的所有path对象2.将pat ...

  4. 《Java数据结构与算法》笔记-CH2有序数组

    /** * 上个例子是无序数组,并且没有考虑重复元素的情况. * 下面来设计一个有序数组,我们设定不允许重复,这样提高查找的速度,但是降低了插入操作的速度. * 1.线性查找 * 2.二分查找 * 有 ...

  5. QT QXmlStreamWriter用法小结

    一 API介绍 writeStartDocument():写文档头,作用类似于创建一个xml文档,并在文档开头部分写入版本信息和编码信息,一般为: <?xml version="1.0 ...

  6. jni 类初始化失败(nested exception is java&period;lang&period;NoClassDefFoundError)

    nested exception is java.lang.NoClassDefFoundError: Could not initialize class com.netease.facedetec ...

  7. JQ 实现轮播图(3D旋转图片轮播效果)

    轮播图效果如下: 代码: <!DOCTYPE html> <html xmlns="/www.w3.org/1999/xhtml"> <head&gt ...

  8. Object类型转换成自定义类型&lpar;向下转型&rpar;

    Object类型转换成自定义类型 场景: 从数据库或者别的途径接收对象的时候用Object,但是用的时候怎么object点(方法提示 | alt+'/'),都点不出自定义类型的方法. 比如,数据库查询 ...

  9. 每天一个linux命令&colon;chgrp

    1.命令简介         chgrp(Change group) 用来将每个指定文件的所属组设置为指定值.如果使用 --reference,则将每个文件的所属组设置为与指定参考文件相同. 2.用法 ...

  10. java添加templates模板,httpServlet模板改写

    为了提高开发效率,通常将一些常用模板添加到快捷键,方法: window-prefrerences-java-editor-templates 代码复制进去apply应用即可 package com.l ...