Wythoff Game

时间限制:1000 ms | 
内存限制:65535 KB

难度:1

描写叙述

近期ZKC同学在学博弈,学到了一个伟大的博弈问题--威佐夫博弈。

相信大家都学过了吧?没学过?没问题。我将要为你讲述一下这个伟大的博弈问题。

有两堆石子,数量随意,能够不同。

游戏開始由两个人轮流取石子。

游戏规定,每次有两种不同的取法:

一是能够在随意的一堆中取走随意多的石子;

二是能够在两堆中同一时候取走同样数量的石子。

最后把石子所有取完者为胜者。

我们今天要做的是求前n个必败态。

什么是必败态?比方我们把(a,b)称为一种状态,a,b分别为两堆石子中所剩的数目。假设a=0,b=0,我们说该种状态为必败态,由于我不能再进行游戏。即使是能够进行。那也是必败的,你知道,游戏的我们都是很聪明的。(0,0)(1,2)(3,5)...都是必败态,我们今天要做的就是求前n个必败态。不会?好吧!

我再告诉你:如果第n个必败态为(a。b)a为前n-1个必败态中没有出现的最小自然数,b=a+n。

这下大家应该明确了吧。

好吧,我们的任务就的要前n个必败态。

规定第0个必败态为(0,0)。

输入

多组数据。

输入为一个数n(0<=n<=100000)。

输出

依照要求求出前n个必败态。输出格式看以下例子。

例子输入

3

1

例子输出

(0,0)(1,2)(3,5)(4,7)

(0,0)(1,2)

提示

注意:每种情况中间没有空格

思路:

就是运用的威佐夫博弈的原始定义。bk=ak+k;ak=(1+sqrt(5))/2*k;

就是简单的暴力枚举。

代码例如以下:

<span style="font-size:14px;">#include<stdio.h>
#include<math.h>
struct sit{
int a,b;
}s[100100];
void f()
{
s[0].a=s[0].b=0;
for(int i=1;i<100100;i++)
{
s[i].a=(1+sqrt(5))*i/2;
s[i].b=s[i].a+i;
}
}
int main()
{
int n;
f();
while(~scanf("%d",&n))
{
for(int i=0;i<=n;i++)
{
printf("(%d,%d)",s[i].a,s[i].b);
}
puts("");
}
return 0;
}</span>

nyoj Wythoff Game(暴力枚举)的更多相关文章

  1. CodeForces 742B Arpa’s obvious problem and Mehrdad’s terrible solution (暴力枚举)

    题意:求定 n 个数,求有多少对数满足,ai^bi = x. 析:暴力枚举就行,n的复杂度. 代码如下: #pragma comment(linker, "/STACK:1024000000 ...

  2. 2014牡丹江网络赛ZOJPretty Poem(暴力枚举)

    /* 将给定的一个字符串分解成ABABA 或者 ABABCAB的形式! 思路:暴力枚举A, B, C串! */ 1 #include<iostream> #include<cstri ...

  3. HNU 12886 Cracking the Safe(暴力枚举)

    题目链接:http://acm.hnu.cn/online/?action=problem&type=show&id=12886&courseid=274 解题报告:输入4个数 ...

  4. 51nod 1116 K进制下的大数 (暴力枚举)

    题目链接 题意:中文题. 题解:暴力枚举. #include <iostream> #include <cstring> using namespace std; ; ; ch ...

  5. Codeforces Round #349 (Div. 1) B. World Tour 最短路+暴力枚举

    题目链接: http://www.codeforces.com/contest/666/problem/B 题意: 给你n个城市,m条单向边,求通过最短路径访问四个不同的点能获得的最大距离,答案输出一 ...

  6. bzoj 1028 暴力枚举判断

    昨天梦到这道题了,所以一定要A掉(其实梦到了3道,有两道记不清了) 暴力枚举等的是哪张牌,将是哪张牌,然后贪心的判断就行了. 对于一个状态判断是否为胡牌,1-n扫一遍,然后对于每个牌,先mod 3, ...

  7. POJ-3187 Backward Digit Sums (暴力枚举)

    http://poj.org/problem?id=3187 给定一个个数n和sum,让你求原始序列,如果有多个输出字典序最小的. 暴力枚举题,枚举生成的每一个全排列,符合即退出. dfs版: #in ...

  8. hihoCoder #1179 : 永恒游戏 (暴力枚举)

    题意: 给出一个有n个点的无向图,每个点上有石头数个,现在的游戏规则是,设置某个点A的度数为d,如果A点的石子数大于等于d,则可以从A点给每个邻接点发一个石子.如果游戏可以玩10万次以上,输出INF, ...

  9. CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)

    问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...

随机推荐

  1. poj1028--动态规划--Ignatius and the Princess III

    Ignatius and the Princess III Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K ...

  2. 搭建自己的websocket server_1

    用Node.js实现一个WebSocket的Server. https://github.com/sitegui/nodejs-websocket#event-errorerr   nodejs-we ...

  3. numpy快速指南

    Quickstart tutorial 引用https://docs.scipy.org/doc/numpy-dev/user/quickstart.html Prerequisites Before ...

  4. html行级元素和块级元素以及css转换

    之前有说过html的标签是有语义的,当然也就有一些默认的样式,比如标题有h1···h6,他们的字体由大至小一次递减,字体比一般字体要加粗. 这样也就有了行级元素和块级元素,下面来看看什么是行级元素什么 ...

  5. Android CollapsingToolbarLayout Toolbar的title覆盖问题

    CollapsingToolbarLayout 里: app:titleEnabled="true" app:title="Hello" Toolbar 里: ...

  6. 自定义SearchView实现即时查询

    1.效果图,输入关键字时会根据关键字改变而更新数据. 2.其布局文件和2个小图标del.png和searchview.png,布局文件如下:高度已固定为46dp. <?xml version=& ...

  7. 决策实验(2)分水岭&哄骗实验

    转载请注明http://www.cnblogs.com/igoslly/p/6824544.html 史密斯实验II PART I 分水岭实验 两种选项 A 50%没钱,50% 45元 B 获取固定数 ...

  8. c++中的while(cin)问题

    xp系统中利用dev-cpp进行编程,语句while(cin>>str),str是个string类型,在一行中输入几个string,末位加个ctrl+z,输入没有结束,除非出入换行后,再输 ...

  9. Kattis -Safe Passage(撑伞问题)

    Safe Passage Photo by Ian Burt A group of friends snuck away from their school campus, but now they ...

  10. OpenGL中着色器,渲染管线,光栅化

    https://www.zhihu.com/question/29163054   光栅(shan一声)化(Rasterize/rasteriztion).这个词儿Adobe官方翻译成栅格化或者像素化 ...