【POJ】【2960】S-Nim

博弈论

  这题跟 BZOJ 1874 取石子游戏 差不多

  先暴力求出10000以内的SG函数(利用定义来求即可)

  然后每次询问直接将SG值异或起来即可……

 

 1 Source Code
 2 Problem: 2960        User: sdfzyhy
 3 Memory: 444K        Time: 313MS
 4 Language: G++        Result: Accepted
 5 
 6     Source Code
 7 
 8     //POJ 2960
 9     #include<cstdio>
10     #include<cstring>
11     #define F(i,j,n) for(int i=j;i<=n;++i)
12     int getint(){
13         int v=0,sign=1; char ch=getchar();
14         while(ch<'0'||ch>'9'){ if (ch=='-') sign=-1; ch=getchar();}
15         while(ch>='0'&&ch<='9'){ v=v*10+ch-'0'; ch=getchar();}
16         return v*=sign;
17     }
18     const int N=10010;
19     /******************tamplate*********************/
20     int f[N],s[101];
21     bool mark[N];
22     void calsg(int n){
23         f[0]=0;
24         F(i,1,10000){
25             memset(mark,0,sizeof mark);
26             F(j,1,n) if (i-s[j]>=0)
27                 mark[f[i-s[j]]]=1;
28             F(j,0,i) if(!mark[j]){ f[i]=j;break;}
29         }
30     }
31     int main(){
32         int n,m,k;
33         while(scanf("%d",&n)!=EOF && n){
34             F(i,1,n) s[i]=getint();
35             m=getint();
36             calsg(n);
37             F(i,1,m){
38                 k=getint();
39                 int ans=0;
40                 F(j,1,k) ans^=f[getint()];
41                 printf(ans ? "W" : "L");
42             }
43             printf("\n");
44         }
45         return 0;
46     }
View Code
posted @ 2015-02-27 22:09  Tunix  阅读(199)  评论(0编辑  收藏  举报