hdu 2999 Stone Game, Why are you always there? (简单SG,有个优化)

题意:

一排石头,个数是K。

有n个数,a1...an。

每人每次取石子只能取连续的x个。x属于a1...an的一个。

没法取者负。

 

思路:

简单的SG。但是TLE!后面加了一个优化~这个优化不好想到吧,看了别人的代码才发现的。就是把a1...an中重复的去掉!。。。

直接看代码。

 

代码:

int sg[1005];
int n,m,k;
int a[105];

int dfs(int x){
    if(sg[x]!=-1)
        return sg[x];
    bool vis[1005]={0};
    rep(i,1,n){
        if(x<a[i]) break;
        for(int j=1;j+a[i]-1<=x;++j){
            int t1=0;
            t1=t1^dfs(j-1);
            t1=t1^dfs(x-j-a[i]+1);
            vis[t1]=true;
        }
    }
    for(int i=0;;++i){
        if(!vis[i]){
            return sg[x]=i;
        }
    }
}
int main(){
    while(scanf("%d",&n)!=EOF){
        rep(i,1,n) scanf("%d",&a[i]);
        sort(a+1,a+1+n);

        ///去重,时间一下缩短一半,这数据....
        int t1=0; int b[105]; b[0]=-1;
        rep(i,1,n) if(a[i]!=b[t1]) b[++t1]=a[i];
        n=t1;
        rep(i,1,n) a[i]=b[i];

        scanf("%d",&m);
        mem(sg,-1);
        while(m--){
            scanf("%d",&k);
            if(!dfs(k))
                puts("2");
            else
                puts("1");
        }
    }
}

 

posted @ 2014-10-03 20:28  fish7  阅读(282)  评论(0编辑  收藏  举报