Fibonacci again and again

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 3610    Accepted Submission(s): 1491

Problem Description
任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的:
F(1)=1;
F(2)=2;
F(n)=F(n-1)+F(n-2)(n>=3);
所以,1,2,3,5,8,13……就是菲波那契数列。
在HDOJ上有不少相关的题目,比如1005 Fibonacci again就是曾经的浙江省赛题。
今天,又一个关于Fibonacci的题目出现了,它是一个小游戏,定义如下:
1、  这是一个二人游戏;
2、  一共有3堆石子,数量分别是m, n, p个;
3、  两人轮流走;
4、  每走一步可以选择任意一堆石子,然后取走f个;
5、  f只能是菲波那契数列中的元素(即每次只能取1,2,3,5,8…等数量);
6、  最先取光所有石子的人为胜者;

假设双方都使用最优策略,请判断先手的人会赢还是后手的人会赢。

 

Input
输入数据包含多个测试用例,每个测试用例占一行,包含3个整数m,n,p(1<=m,n,p<=1000)。
m=n=p=0则表示输入结束。
 

Output
如果先手的人能赢,请输出“Fibo”,否则请输出“Nacci”,每个实例的输出占一行。
 

Sample Input
1 1 1
1 4 1
0 0 0
 

Sample Output
Fibo
Nacci
 

Author
lcy
 

Source
 

Recommend
lcy
 

SG_DFS:呵呵,第一次在 杭电 用栈外挂。。。。

#include <iostream>
#include <cstdio>
#include <cstring>
#pragma comment(linker, "/STACK:1024000000,1024000000")

using namespace std;

int fib[17],n,m,p,sg[1100];

int SG_dfs(int x)
{
    if(sg[x]!=-1) return sg[x];
    bool vis[1100]; int i;
    memset(vis,false,sizeof(vis));
    for(i=0;fib<=x&&i<17;i++)
    {
        SG_dfs(x-fib);
        vis[sg[x-fib]]=true;
    }
    for(i=0;i<=1000;i++)
    {
        if(!vis) break;
    }
    return sg[x]=i;
}

int main()
{
    fib[0]=fib[1]=1;
    for(int i=2;i<17;i++)
        fib=fib[i-1]+fib[i-2];
    memset(sg,-1,sizeof(sg));
    while(scanf("%d%d%d",&n,&m,&p)!=EOF)
    {
        if(!(n||m||p)) break;
        int XOR=0;
        XOR=SG_dfs(n)^SG_dfs(m)^SG_dfs(p);
        if(!XOR) puts("Nacci");
        else puts("Fibo");
    }
    return 0;
}

* This source code was highlighted by YcdoiT. ( style: Codeblocks )

getSG:

#include <iostream>
#include <cstdio>
#include <cstring>
#pragma comment(linker, "/STACK:1024000000,1024000000")

using namespace std;

int fib[17],n,m,p,sg[1100];

void getSG()
{
    for(int i=1;i<=1000;i++)
    {
        bool flag[1100];
        memset(flag,false,sizeof(flag));
        for(int j=0;fib[j]<=i&&j<17;j++)
        {
            flag[sg[i-fib[j]]]=true;
        }
        for(int j=0;j<=1000;j++)
        {
            if(!flag[j])
            {
                sg=j; break;
            }
        }
    }
}

int main()
{
    fib[0]=fib[1]=1;
    for(int i=2;i<17;i++)
        fib=fib[i-1]+fib[i-2];
    memset(sg,0,sizeof(sg));
    getSG();
    while(scanf("%d%d%d",&n,&m,&p)!=EOF)
    {
        if(!(n||m||p)) break;
        int XOR=0;
        XOR=sg[n]^sg^sg[p];
        if(!XOR) puts("Nacci");
        else puts("Fibo");
    }
    return 0;
}

* This source code was highlighted by YcdoiT. ( style: Codeblocks )

 

HDOJ 1848 Fibonacci again and again的更多相关文章

  1. hdu 1848 Fibonacci again and again(SG函数)

    Fibonacci again and again HDU - 1848 任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的: F(1)=1; F(2)= ...

  2. HDU 1848 Fibonacci again and again (斐波那契博弈SG函数)

    Fibonacci again and again Time Limit: 1000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & ...

  3. hdu 1848 Fibonacci again and again(简单sg)

    Problem Description 任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的:F(1)=1;F(2)=2;F(n)=F(n-1)+F(n-2 ...

  4. HDU 1848 Fibonacci again and again(SG函数)

    Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission( ...

  5. HDU 1848 Fibonacci again and again【博弈SG】

    Problem Description 任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的: F(1)=1; F(2)=2; F(n)=F(n-1)+F( ...

  6. hdu 1848 Fibonacci again and again(sg)

    Fibonacci again and again Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Jav ...

  7. 题解报告:hdu 1848 Fibonacci again and again(尼姆博弈)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1848 Problem Description 任何一个大学生对菲波那契数列(Fibonacci num ...

  8. 博弈论 SG函数(模板) HDU 1848 Fibonacci again and again

    Fibonacci again and again Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Jav ...

  9. 【HDU】1848 Fibonacci again and again

    http://acm.hdu.edu.cn/showproblem.php?pid=1848 题意:同nim,3堆,每次取的为fib数,n<=1000 #include <cstdio&g ...

随机推荐

  1. git的简介,安装以及使用

    1git的简介 Git是什么? Git是目前世界上最先进的分布式版本控制系统(没有之一). Git有什么特点?简单来说就是:高端大气上档次! 2Linus一直痛恨的CVS及SVN都是集中式的版本控制系 ...

  2. Canvas 教程

    在本文章中 在你开始之前 教程内容 相关资料 A note to contributors <canvas> 是一种可以通过编写脚本(通常是JavaScript)来实现绘制图形的HTML元 ...

  3. 【Lucene实验1】构建索引

    一.实验名称:构建索引 二.实验日期:2013/9/21 三.实验目的: 1)        能理解Lucene中的Document-Field结构的数据建模过程: 2)        能编针对特定数 ...

  4. UEditor编辑文章出现多余空行问题的解决办法

    网站后台管理编辑文章以后,保存.再次打开编辑是文章前后多出多余的空行.一直以为是编辑器有问题,也没在意,但是自己编辑文章多了,感觉太麻烦了.想一定可以解决这个问题.百度一下果然找到原因.原来是加载编辑 ...

  5. css的6中居中的方式

    请先看blog:http://blog.csdn.net/wolinxuebin/article/details/7615098

  6. Linq之Expression高级篇(常用表达式类型)

    目录 写在前面 系列文章 变量表达式 常量表达式 条件表达式 赋值表达式 二元运算符表达式 一元运算符表达式 循环表达式 块表达式 总结 写在前面 首先回顾一下上篇文章的内容,上篇文章介绍了表达式树的 ...

  7. java多线程-Exchanger

    简介: 可以在对中对元素进行配对和交换的线程的同步点.每个线程将条目上的某个方法呈现给exchange方法,与伙伴线程进行匹配,并且在返回时接收其伙伴的对象.Exchanger 可能被视为Synchr ...

  8. Linux_日志信息

    一.httpd日志:/var/log/httpd1.软件位置:whereis httpd2.配置文件位置:/etc/httpd/conf/httpd.conf 二.mysql日志:/var/log 查 ...

  9. BZOJ-3225 立方体覆盖 线段树+扫描线+乱搞

    看数据范围像是个暴力,而且理论复杂度似乎可行,然后被卡了两个点...然后来了个乱搞的线段树+扫描线.. 3225: [Sdoi2008]立方体覆盖 Time Limit: 2 Sec Memory L ...

  10. 最新版本的DBCP数据源配置

    弄了我一下午,把该加的包都加进去了还是没用,后来把DBCP的包打开来看看才发现路径不对.配置如下: <!-- 使用dbcp配置数据源 --> <bean id="dataS ...