VijosP1208欧几里德的游戏 博弈

欧几里德的游戏

题目描述


几里德的两个后代Stan和Ollie正在玩一种数字游戏,这个游戏是他们的祖先欧几里德发明的。给定两个正整数M和N,从Stan开始,从其中较大的一
个数,减去较小的数的正整数倍,当然,得到的数不能小于0。然后是Ollie,对刚才得到的数,和M,N中较小的那个数,再进行同样的操作……直到一个人
得到了0,他就取得了胜利。下面是他们用(25,7)两个数游戏的过程:
    Start:25 7
    Stan:11 7
    Ollie:4 7
    Stan:4 3
    Ollie:1 3
    Stan:1 0
    Stan赢得了游戏的胜利。
现在,假设他们完美地操作,谁会取得胜利呢?

输入

第一行为测试数据的组数C。下面有C行,每行为一组数据,包含两个正整数M, N。(M, N不超过长

输出

对每组输入数据输出一行,如果Stan胜利,则输出“Stan wins”;否则输出“Ollie wins”

样例输入

2
25 7
24 15

样例输出

Stan wins
Ollie wins

 假设博弈现在从Stan开始 (1)如果 n % m == 0 先手stan 可以直接获胜 (2)如果 n / m > 1 && n%m != 0, 先手stan 可以使 n = n%m + m > m, Ollie只可以取 n%m , 剩下 (m , m), 故 stan 赢 (3)那么其他情况, 轮到对手的选择权, 如此反复直到达到(1)、(2)结束

 1 #include <iostream>
 2 #include <sstream>
 3 #include <fstream>
 4 #include <string>
 5 #include <vector>
 6 #include <deque>
 7 #include <queue>
 8 #include <stack>
 9 #include <set>
10 #include <map>
11 #include <algorithm>
12 #include <functional>
13 #include <utility>
14 #include <bitset>
15 #include <cmath>
16 #include <cstdlib>
17 #include <ctime>
18 #include <cstdio>
19 #include <cstring>
20
21 using namespace std;
22
23
24 typedef long long int ll;
25 typedef pair<int, int> P;
26 int read() {
27     int x=0,f=1;
28     char ch=getchar();
29     while(ch<‘0‘||ch>‘9‘) {
30         if(ch==‘-‘)f=-1;
31         ch=getchar();
32     }
33     while(ch>=‘0‘&&ch<=‘9‘) {
34         x=x*10+ch-‘0‘;
35         ch=getchar();
36     }
37     return x*f;
38 }
39 const double pi=3.14159265358979323846264338327950288L;
40 const double eps=1e-10;
41 const int mod = 1e9 + 7;
42 const int INF = 0x3f3f3f3f;
43 const int INT = 0x7fffffff;
44 const int MAXN = 433;
45 const int xi[] = {0, 0, 1, -1};
46 const int yi[] = {1, -1, 0, 0};
47
48
49 int main() {
50     int n, m, t;
51     scanf("%d", &t);
52     while(t--){
53         scanf("%d%d", &n, &m);
54         if(n < m) swap(n, m);
55         int Stan = 1;
56         while(n/m == 1 && n%m){
57             int t = n%m;
58             n = m;
59             m = t;
60             Stan = -Stan;
61         }
62         if(Stan == 1) printf("Stan wins\n");
63         else printf("Ollie wins\n");
64     }
65     return 0;
66 }

时间: 2024-08-14 03:48:34

VijosP1208欧几里德的游戏 博弈的相关文章

洛谷P1290 欧几里德的游戏 数学 博弈论 模拟

洛谷P1290 欧几里德的游戏 数学 博弈论 模拟 这道题我们因为当 x 大于 y 时 你也只能在合法范围 内取 1 个 y 两个 y 也就是说 能取的y大于等于2时,则你本质不同的取法共有两种,此时你必定获胜,因为本质不同,而在最优策略下,则说明胜利者也不同,也就是说这时候你可以决定自己的输赢 ,我们称这种必胜局为 v 局 2.但是如果 v 局后面还有v 局怎么办,这个不必担心,因为先拿到 v局的人,有两种本质不同的取法,也就是说 他可以控制自己下次必定拿到 v 局,这样就 能确保胜利了 所以

洛谷——P1290 欧几里德的游戏

P1290 欧几里德的游戏 题目描述 欧几里德的两个后代Stan和Ollie正在玩一种数字游戏,这个游戏是他们的祖先欧几里德发明的.给定两个正整数M和N,从Stan开始,从其中较大的一个数,减去较小的数的正整数倍,当然,得到的数不能小于0.然后是Ollie,对刚才得到的数,和M,N中较小的那个数,再进行同样的操作……直到一个人得到了0,他就取得了胜利.下面是他们用(25,7)两个数游戏的过程: Start:25 7 Stan:11 7 Ollie:4 7 Stan:4 3 Ollie:1 3 S

欧几里德的游戏

题目描述 欧几里德的两个后代Stan和Ollie正在玩一种数字游戏,这个游戏是他们的祖先欧几里德发明的.给定两个正整数M和N,从Stan开始,从其中较大的一个数,减去较小的数的正整数倍,当然,得到的数不能小于0.然后是Ollie,对刚才得到的数,和M,N中较小的那个数,再进行同样的操作--直到一个人得到了0,他就取得了胜利.下面是他们用(25,7)两个数游戏的过程: Start:25 7 Stan:11 7 Ollie:4 7 Stan:4 3 Ollie:1 3 Stan:1 0 Stan赢得

HDU 2176 取(m堆)石子游戏 博弈

取(m堆)石子游戏 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 3598    Accepted Submission(s): 2151 Problem Description m堆石子,两人轮流取.只能在1堆中取.取完者胜.先取者负输出No.先取者胜输出Yes,然后输出怎样取子.例如5堆 5,7,8,9,10先取者胜,先取者第1次取

洛谷 1290 欧几里德的游戏

https://www.luogu.org/problem/show?pid=1290 题目描述 欧几里德的两个后代Stan和Ollie正在玩一种数字游戏,这个游戏是他们的祖先欧几里德发明的.给定两个正整数M和N,从Stan开始,从其中较大的一个数,减去较小的数的正整数倍,当然,得到的数不能小于0.然后是Ollie,对刚才得到的数,和M,N中较小的那个数,再进行同样的操作--直到一个人得到了0,他就取得了胜利.下面是他们用(25,7)两个数游戏的过程: Start:25 7 Stan:11 7

51NOD 算法马拉松15(脱欧专场) B君的游戏(博弈)

传送门 B君的游戏 wwwwodddd (命题人) 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 B君和L君要玩一个游戏.刚开始有n个正整数 ai . 双方轮流操作.每次操作,选一个正整数x,将其移除,再添加7个数字 x1,x2-x7 .要求对于 xi ,满足 0<= xi < x 且 x&xi=xi 注意0不能被选取,所以这个游戏一定会结束,而谁无法操作谁就失败. B君根据自己的经验,认为先手胜率高一点,所以B君是先手. B君想知道自己是否必胜. Input 第一

P1290 欧几里德的游戏

题目描述 欧几里德的两个后代Stan和Ollie正在玩一种数字游戏,这个游戏是他们的祖先欧几里德发明的.给定两个正整数M和N,从Stan开始,从其中较大的一个数,减去较小的数的正整数倍,当然,得到的数不能小于0.然后是Ollie,对刚才得到的数,和M,N中较小的那个数,再进行同样的操作……直到一个人得到了0,他就取得了胜利.下面是他们用(25,7)两个数游戏的过程: Start:25 7 Stan:11 7 Ollie:4 7 Stan:4 3 Ollie:1 3 Stan:1 0 Stan赢得

(转载)Nim游戏博弈(收集完全版)

Nim游戏的概述: 还记得这个游戏吗?给出n列珍珠,两人轮流取珍珠,每次在某一列中取至少1颗珍珠,但不能在两列中取.最后拿光珍珠的人输.后来,在一份资料上看到,这种游戏称为“拈(Nim)”.据说,它源自中国,经由被贩卖到美洲的奴工们外传.辛苦的工人们,在工作闲暇之余,用石头玩游戏以排遣寂寞.后来流传到高级人士,则用便士(Pennies),在酒吧柜台上玩.最有名的玩法,是把十二枚便士放成3.4.5三列,拿光铜板的人赢.后来,大家发现,先取的人只要在3那列里取走2枚,变成了1.4.5,就能稳操胜券了

LGOJ1290 欧几里德的游戏

题目链接 P1290 and UVA10368 (双倍经验[虽然标签差距很有趣]) 题目大意 给定两个数\(n\)和\(m\),每次操作可以用较大数减去较小数的正整数倍,不可以减成负数. 先获得一个\(0\)的人获胜,问先手是否必胜. \(n,m \leq 2^{31}-1\) 多组数据. Solution 一眼博弈论题吧2333 \(SG\)函数和递归操作应该是摆在眼前的 先记较大数为\(n\),较小数为\(m\) 三种情况: 1.如果当前态的\(n\)和\(m\)中有一个已经是\(0\)了