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. Wannafly挑战赛25 C 期望操作数 数学

    题目 题意:给你你一个数x和一个数q,x<=q,每一次可以等概率把x变成[x,q]中任意一个数,问变成q的步数的期望,输出对998244353取模,多组询问 题解:首先肯定的是,可以预处理,因为 ...

  2. SwiftUI 官方教程(八)

    8. 动态生成预览 接下来,我们会在 LandmarkList_Previews 中添加代码以在不同的设备尺寸上渲染列表.默认情况下,预览会以当前的 scheme 中设备的大小进行渲染.我们可以通过调 ...

  3. Unity3d Time

    using UnityEngine; using System.Collections; public class test1 : MonoBehaviour { public float angle ...

  4. JavaEE学习记录

    软件152谭智馗 一.JavaEE开发环境配置 1.准备以下压缩包 (1)JDK1.7:jdk1.7.rar (2)开发工具:eclipse-jee-mars-2 (3)项目管理工具:maven-3. ...

  5. Sql Server 优化----SQL语句的执行方式与锁以及阻塞的关系

    阻塞原因之一是不同的Session在访问同一张表的时候因为不兼容锁的原因造成的, 当前执行的SQL语句是否被阻塞(或者死锁),不仅跟当前表上的已有的锁有关,也会跟当前执行的SQL语句的执行方式有关 简 ...

  6. shell学习第二弹-进阶

    1.linux系统中配置文件执行顺序 1)用户登录系统,首页调用/etc/profile文件初始化所有bash用户的默认特征 2)然后shell依次查找~/.bash_profile,~/.bash_ ...

  7. (转载)tnsping不是内部或外部命令

    手动添加 D:\app\Administrator\product\11.2.0\client_1\bin 到系统环境变量 path里面

  8. in 与 exist , not in 与 not exist

    in和exists in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询.一直以来认为exists比in效率高的说法是不准确的. 如果查询的两个 ...

  9. 基于连接的Java网络编程

    实现了基于TCP的Java Socket编程,功能很简单:客户端向服务器端输出一名话"connect",服务器端接收输出到控制台并向客户端输出一名话"Hello" ...

  10. C++序列化使用

    error C2248 无法访问私有成员 :原因 ifstream 作为参数必须传引用! (1):C++使用STL序列化:原文链接:http://blog.csdn.net/pandaxcl/arti ...