hdu 1536 S-Nim (简单sg函数)

题意:首先输入K 表示一个集合的大小  之后输入集合 表示对于这对石子只能去这个集合中的元素的个数

之后输入 一个m 表示接下来对于这个集合要进行m次询问 

之后m行 每行输入一个n 表示有n个堆  每堆有n1个石子  问这一行所表示的状态是赢还是输 如果赢输入W否则L

思路:sg打表一下

#include <iostream>
#include <cstring>
using namespace std;
const int maxn=10008;

int f[maxn],n;//n代表集合元素的个数
int sg[maxn];
bool has[maxn];

void getsg()
{
    memset(sg,0,sizeof(sg));
    for(int i=1;i<=maxn;i++)
    {
        memset(has,false,sizeof(has));
        for(int j=1;j<=n;j++)
        {
            if(i>=f[j])
             has[sg[i-f[j]]]=true;
        }
        for(int j=0;j<=maxn;j++)
        {
            if(has[j]==false)
            {
                sg[i]=j;
                break;
            }
        }
    }
}

int main()
{
    while(cin>>n&&n)
    {
        string ou="";
        for(int i=1;i<=n;i++)
        cin>>f[i];
        getsg();
        int m;
        cin>>m;
        while(m--)
        {
            int t;
            int ans=0;
            cin>>t;
            for(int i=1;i<=t;i++)
            {
                int k;
                cin>>k;
                ans=ans^sg[k];
            }
            if(ans)
            ou+='W';
            else
            ou+='L';
        }
        cout<<ou<<endl;
    }
    return 0;
}

 

posted @ 2016-12-01 19:44  邻家那小孩儿  阅读(268)  评论(0编辑  收藏  举报