HDU 1848

http://acm.hdu.edu.cn/showproblem.php?pid=1848

利用计算grundy数组,把一类博弈转化为nim博弈,最后x不为0为先手必胜态

#include <iostream>
#include <cstdio>
#include <cstring>
#include <set>
#include <algorithm>
using namespace std ;

//N堆硬币,每堆Xi
//每次从一堆中取a1 a2...ak,先取完胜 

const int MAX_X=1005 ;
const int MAX_K=25 ;
const int MAX_N=5 ;

int N,K,X[MAX_N],A[MAX_K] ;

int grundy[MAX_X] ; 

void solveSG()
{
    grundy[0]=0 ;
    //int max_x=*max_element(X,X+N) ;
    for(int j=1 ;j<=1000 ;j++)
    {
        set <int> s ;
        for(int i=0 ;A[i]<=j ;i++)//A[i]<=j
        {
            if(A[i]<=j)s.insert(grundy[j-A[i]]) ;
        }
        int g=0 ;
        while(s.count(g)!=0)g++ ;
        grundy[j]=g ;
    }
    /*
    int x=0 ;
    for(int i=0 ;i<N ;i++)x^=grundy[X[i]] ;
    if(x)puts("Fibo") ;//先手胜
    else puts("Nacci") ;//后手胜
    */
} 

int main()
{
    A[0]=A[1]=1 ;
    for(int i=2 ;i<20 ;i++)
        A[i]=A[i-1]+A[i-2] ;
    solveSG() ;
    while(~scanf("%d%d%d",&X[0],&X[1],&X[2]))
    {
        if(!X[0] && !X[1] && !X[2])break ;
        int x=0 ;
        for(int i=0 ;i<3 ;i++)x^=grundy[X[i]] ;
        if(x)puts("Fibo") ;//先手胜
        else puts("Nacci") ;//后手胜
    }
    return 0 ;
}

时间: 2024-10-07 08:47:17

HDU 1848的相关文章

HDU - 1848 - Fibonacci again and again

先上题目: Fibonacci again and again Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 4964    Accepted Submission(s): 2072 Problem Description 任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的:F(1)=1;F

hdu 1848 博弈之SG函数的使用

题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1848 题目简单描述为: 1.  这是一个二人游戏;2.  一共有3堆石子,数量分别是m, n, p个:3.  两人轮流走;4.  每走一步可以选择任意一堆石子,然后取走f个:5.  f只能是菲波那契数列中的元素(即每次只能取1,2,3,5,8-等数量):6.  最先取光所有石子的人为胜者:假设双方都使用最优策略,请判断先手的人会赢还是后手的人会赢. 代码为: ? 1 2 3 4 5 6 7 8 9

HDU 1848 Fibonacci again and again(博弈 SG运用)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1848 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就是曾经的浙江省赛题. 今天,又一个关于Fi

HDU 1848 Fibonacci again and again(简单博弈SG函数)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1848 题目: 1.  这是一个二人游戏;2.  一共有3堆石子,数量分别是m, n, p个:3.  两人轮流走;4.  每走一步可以选择任意一堆石子,然后取走f个:5.  f只能是菲波那契数列中的元素(即每次只能取1,2,3,5,8-等数量):6.  最先取光所有石子的人为胜者:假设双方都使用最优策略,请判断先手的人会赢还是后手的人会赢. Input 输入数据包含多个测试用例,每个测试用例占一行,包

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

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1848 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就是曾经的浙江省赛题.今天,又一个关于Fibonacc

hdu 1848 简单SG函数

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1848 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就是曾经的浙江省赛题.今天,又一个关于Fibonacc

hdu 1848 Fibonacci again and again 博弈论,求出SG函数,,什么问题都没有了

Fibonacci again and again Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 5596    Accepted Submission(s): 2354 Problem Description 任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的: F(1)=1; F(2)

HDU 1848 —— Fibonacci again and again 【博弈 sg函数】

Fibonacci again and again Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) 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上

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)(n>=3);所以,1,2,3,5,8,13--就是菲波那契数列.在HDOJ上有不少相关的题目,比如1005 Fibonacci again就是曾经的浙江省赛题.今天,又一个关于Fibonacci的题目出现了,它是一个小游戏,定义如下:1.  这是一个二人游戏;2.  一共有3堆石子,数量分别是m