http://poj.org/problem?id=2348

顺便说,必应翻译真的好用,比谷歌翻译好用100倍。

很难判断这道题的具体博弈类型。

有两种写法,一种是找规律,一种是推理得到关系后循环(或递归)处理。两种写法都能在题目下面的discuss中找到。

1.找规律,我在这里直接复制了discuss中大神算出的sg函数表(在考试中这种写法是很值得借鉴的,这里就体现出代码能力的重要了,找规律天下第一!)。

我算了一下前 30 × 30 的 Sprague-Grundy 函数表,如下:

      0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
-----------------------------------------------------------------------------------------------
0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
1 | 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
2 | 0 2 1 0 2 1 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15
3 | 0 3 0 1 0 1 2 1 2 3 2 3 4 4 4 5 5 5 6 6 6 7 7 7 8 8 8 9 9 9 10
4 | 0 4 2 0 1 0 0 1 2 1 1 2 3 2 3 3 4 3 4 4 5 5 5 5 6 6 6 6 7 7 7
5 | 0 5 1 1 0 1 0 0 0 1 2 1 2 2 2 3 2 3 3 3 4 3 4 4 4 5 4 5 5 5 6
6 | 0 6 3 2 0 0 1 0 0 0 1 1 2 1 1 1 2 2 3 2 2 3 3 3 4 3 4 4 4 4 5
7 | 0 7 3 1 1 0 0 1 0 0 0 0 1 1 2 1 1 2 2 2 2 3 2 2 3 3 3 3 4 3 4
8 | 0 8 4 2 2 0 0 0 1 0 0 0 0 1 1 1 2 1 1 1 1 2 2 2 3 2 2 3 3 3 3
9 | 0 9 4 3 1 1 0 0 0 1 0 0 0 0 0 1 1 1 2 1 1 1 2 2 2 2 2 3 2 2 2
10 | 0 10 5 2 1 2 1 0 0 0 1 0 0 0 0 0 0 1 1 1 2 1 1 1 2 1 2 2 2 2 3
11 | 0 11 5 3 2 1 1 0 0 0 0 1 0 0 0 0 0 0 1 1 1 1 2 1 1 1 1 2 2 2 2
12 | 0 12 6 4 3 2 2 1 0 0 0 0 1 0 0 0 0 0 0 0 1 1 1 1 2 1 1 1 1 1 1
13 | 0 13 6 4 2 2 1 1 1 0 0 0 0 1 0 0 0 0 0 0 0 0 1 1 1 1 2 1 1 1 1
14 | 0 14 7 4 3 2 1 2 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 1 1 1 1 1 2 1 1
15 | 0 15 7 5 3 3 1 1 1 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 1 1 1 1 1 2
16 | 0 16 8 5 4 2 2 1 2 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 1 1 1 1 1
17 | 0 17 8 5 3 3 2 2 1 1 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 1 1 1
18 | 0 18 9 6 4 3 3 2 1 2 1 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 1
19 | 0 19 9 6 4 3 2 2 1 1 1 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0
20 | 0 20 10 6 5 4 2 2 1 1 2 1 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0
21 | 0 21 10 7 5 3 3 3 2 1 1 1 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0
22 | 0 22 11 7 5 4 3 2 2 2 1 2 1 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0
23 | 0 23 11 7 5 4 3 2 2 2 1 1 1 1 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0
24 | 0 24 12 8 6 4 4 3 3 2 2 1 2 1 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0
25 | 0 25 12 8 6 5 3 3 2 2 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0
26 | 0 26 13 8 6 4 4 3 2 2 2 1 1 2 1 1 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0
27 | 0 27 13 9 6 5 4 3 3 3 2 2 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0
28 | 0 28 14 9 7 5 4 4 3 2 2 2 1 1 2 1 1 1 0 0 0 0 0 0 0 0 0 0 1 0 0
29 | 0 29 14 9 7 5 4 3 3 2 2 2 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 1 0
30 | 0 30 15 10 7 6 5 4 3 2 3 2 1 1 1 2 1 1 1 0 0 0 0 0 0 0 0 0 0 0 1

可以发现0的分界线在黄金分割比附近,直接算一个边界就可以了。边界不好看清的话可以上下拖动滚动条。(我大概有病orz,不过真的能看见,希望大家试试)

代码

 #include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<map>
#include<ctime>
using namespace std;
const int maxn=<<;
int n;
int main(){
long long x,y;
while(~scanf("%lld%lld",&x,&y)){
if(x==&&y==)break;
if(x>y)swap(x,y);
long long w=((double)x*2.0/(sqrt(5.0)-1.0));
if(y<=w&&y!=x)printf("Ollie wins\n");
else printf("Stan wins\n");
}
return ;
}

1.根据规则进行推理,在日常写题还是很推荐这种写法的,毕竟博弈论能找到规律的毕竟只是一部分,大部分不用dp的博弈论都是相应对策或者必胜选择的推理(个人感受不一定对)。

记每次一个人开始操作前的两数大的为y,小的x。

全程两人都没有选择(每次的情况都满足y减去一次x就比x小)的时候结果是一定的,那么直接循环找出最终胜利者就可以了(显然满足这种条件的时候循环次数不会太多)。

假如其中有一个人有选择(y可以减n次小的才比x小,n>1)的时候,这个人如果在y中取n个x时必输,这个人就可以在y中取n-1个x,那么对方就必输。

于是有了一个循环解决的写法。

代码

 #include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<map>
#include<ctime>
using namespace std;
const int maxn=<<;
int n;
int main(){
long long x,y;
while(~scanf("%lld%lld",&x,&y)){
if(x==&&y==)break;
if(x>y)swap(x,y);
int w=;
while(x!=){
if(y%x==||y-x>x)break;
y-=x;
w^=;
if(x>y)swap(x,y);
}
if(w)printf("Ollie wins\n");
else printf("Stan wins\n");
}
return ;
}

POJ 2348 Euclid's Game 博弈论的更多相关文章

  1. poj 2348 Euclid's Game 题解

    Euclid's Game Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9023   Accepted: 3691 Des ...

  2. POJ 2348 Euclid's Game(博弈论)

    [题目链接] http://poj.org/problem?id=2348 [题目大意] 给出两个数,两个参赛者轮流用一个数减去另一个数的倍数,当一个数为0的时候游戏获胜, 求先手是否必胜 [题解] ...

  3. POJ 2348 Euclid's Game(辗转相除博弈+自由度分析)

    题目链接:http://poj.org/problem?id=2348 题目大意:给你两个数a,b,Stan和Ollie轮流操作,每次可以将较大的数减去较小的数的整数倍,相减后结果不能小于0,谁先将其 ...

  4. POJ 2348 Euclid's Game【博弈】

    题目链接: http://poj.org/problem?id=2348 题意: 给定两个数,两个人每次从较大数中减去较小数的倍数,谁先得到0谁获胜,为谁赢? 分析: 令一种可能出现的整数对为(a,b ...

  5. POJ 2348 Euclid's Game(博弈)题解

    题意:有a,b两个数字,两人轮流操作,每次可以选择两个之中较小的数字,然后另一个数字减去选择数字的任意倍数(不能减到负数),直到其中一个为0,不能操作为败 思路:这题用博弈NP思想,必败点和必胜点之间 ...

  6. POJ 2348 Euclid Game (模拟题)

    Euclid's Game Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7942   Accepted: 3227 Des ...

  7. POJ 2348 Euclid's Game(简单博弈)

    这道题没说a b最大多少,所以要声明为long long型,不然会WA! 道理很简单,(默认a>=b)a和b只有以下三种关系: 1.a%b==0 :这种关系下,可能是a/b为整数,也可能是a和b ...

  8. poj 2348 Euclid's Game

    题目: 给两个整数a和b,两个人先后用较大的数减去较小数的整数倍,并且保证相减后为非负数.先把一个数变为0的人获胜. 分析: 很显然,当大数是小数的整数倍时为必胜态. 从这道题学会一个叫做自由度的东西 ...

  9. POJ 2348 Euclid's Game (博弈)

    题意:给定两个整数,两个人轮流操作,每次可以用较大数减去较小数的整数倍,当一个数变成0时,则结束,问谁会胜. 析:很明显如果 a == b 那么就可以直接结束了,那么如果 a > b我们可以交换 ...

随机推荐

  1. 【BZOJ】1585: [Usaco2009 Mar]Earthquake Damage 2 地震伤害

    [题意]给定无向图,现在可能有一些点已经被删除,只给出信息是c个点未被删除且不能到达结点1,求最少的删除点个数. [算法]最小割 [题解]本题和1的区别是:1求的是最少的不能到达1的结点数,那么就把损 ...

  2. UIDatePicker---iOS-Apple苹果官方文档翻译

    本系列所有开发文档翻译链接地址: iOS7开发-Apple苹果iPhone开发Xcode官方文档翻译PDF下载地址  UIDatePicker //转载请注明出处--本文永久链接:http://www ...

  3. 程序员你为什么这么累? - Controller规范

    导读:程序员你为什么这么累? 接口定义:程序员你为什么这么累? - 接口定义 第一篇文章中,我贴了2段代码,第一个是原生态的,第2段是我指定了接口定义规范,使用AOP技术之后最终交付的代码,从15行到 ...

  4. 【洛谷 P2303】 [SDOi2012]Longge的问题 (欧拉函数)

    题目链接 题意:求\(\sum_{i=1}^{n}\gcd(i,n)\) 首先可以肯定,\(\gcd(i,n)|n\). 所以设\(t(x)\)表示\(gcd(i,n)=x\)的\(i\)的个数. 那 ...

  5. scrapy学习笔记一

    以前写爬虫都是直接手写获取response然后用正则匹配,被大佬鄙视之后现在决定开始学习scrapy 一.安装 pip install scrapy 二.创建项目 scrapy startprojec ...

  6. glob模块的使用

    glob模块 功能描述:glob模块可以使用Unix shell风格的通配符匹配符合特定格式的文件和文件夹,跟windows的文件搜索功能差不多.glob模块并非调用一个子shell实现搜索功能,而是 ...

  7. python近期遇到的一些面试问题(二)

    1. 解释什么是栈溢出,在什么情况下可能出现. 栈溢出是由于C语言系列没有内置检查机制来确保复制到缓冲区的数据不得大于缓冲区的大小,因此当这个数据足够大的时候,将会溢出缓冲区的范围.在Python中, ...

  8. .build_release/lib/libcaffe.so: undefined reference to `cv::VideoCapture::set(int, double)'

    CXX/LD -o .build_release/tools/convert_imageset.bin.build_release/lib/libcaffe.so: undefined referen ...

  9. RabbitMQ 基础知识

    1. 背景 RabbitMQ 是一个由 erlang 开发的AMQP 开源实现,erlang语言天生具备高并发的特性,而且他的管理界面用起来十分方便. 基础概念 讲解基础概念的前面,我们先来整体构造一 ...

  10. django “如何”系列9:三合一:利用遗留的数据库、输出csv和输出pdf

    如何集成遗留的数据库 django在适合开发新应用的同时,可以可以集成以前遗留的数据库,下面是如何集成一个已经存在的数据库的流程. 给定你的数据库的参数 你需要告诉django你的数据库连接参数以及数 ...