博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ1704 Georgia and Bob 博弈论 尼姆博弈 阶梯博弈
阅读量:5076 次
发布时间:2019-06-12

本文共 1092 字,大约阅读时间需要 3 分钟。

我并不知道阶梯博弈是什么玩意儿,但是这道题的所有题解博客都写了这个标签,所以我也写了,百度了一下,大概是一种和这道题类似的能转换为尼姆博弈的博弈。

解法大概是配对之后的尼姆博弈,没看到一个格子只能放一个石头(以为可以直接把石头移动到前一个石头在的格子),所以莫名其妙wa了orz,总是因为题目被踩爆orz

其实博弈也是个很神奇的东西,现在这个东西给我的印象又变成配对找规律了(泪),虽然看上去从后往前两两配对的做法很有道理但是迫切需要更数学的解释(这个东西似乎更数学的解释看不懂orz)

嗯做法就是从后往前两两配对(奇数个就把第一个和位置0配对),然后显然(完全不)当每对的前一个移动时,后一个也一定可以移动同样步数,后一个移动时对前一个并没有什么影响,所以把每一对的两个的位置差异或起来就好了(不要直接减…要明白,每一对里后一个能移动的步数最多为两个的位置差-1)。

1 #include
2 #include
3 #include
4 #include
5 #include
6 #include
7 using namespace std; 8 const int maxn=1010; 9 int T,n;10 int a[maxn]={};11 int main(){12 scanf("%d",&T);13 while(T-->0){14 scanf("%d",&n);15 int y=0;16 for(int i=1;i<=n;i++){17 scanf("%d",&a[i]);18 }sort(a+1,a+1+n);19 if(n&1){20 for(int i=1;i<=n;i+=2){21 y^=a[i]-a[i-1]-1;22 }23 }24 else{25 for(int i=2;i<=n;i+=2){26 y^=a[i]-a[i-1]-1;27 }28 }29 if(y)printf("Georgia will win\n");30 else printf("Bob will win\n");31 }32 return 0;33 }
View Code

 

转载于:https://www.cnblogs.com/137shoebills/p/8145515.html

你可能感兴趣的文章
计算机基础作业1
查看>>
Ubuntu 深度炼丹环境配置
查看>>
C#中集合ArrayList与Hashtable的使用
查看>>
从一个标准 url 里取出文件的扩展名
查看>>
map基本用法
查看>>
poj-1163 动态规划
查看>>
Golang之interface(多态,类型断言)
查看>>
Redis快速入门
查看>>
BootStrap---2.表格和按钮
查看>>
Linear Algebra lecture 2 note
查看>>
CRC计算模型
查看>>
Ajax之404,200等查询
查看>>
Aizu - 1378 Secret of Chocolate Poles (DP)
查看>>
csv HTTP简单表服务器
查看>>
OO设计的接口分隔原则
查看>>
数据库连接字符串大全 (转载)
查看>>
java类加载和对象初始化
查看>>
对于负载均衡的理解
查看>>
django简介
查看>>
window.event在IE和Firefox的异同
查看>>