S-Nim
Time Limit: 2000MS   Memory Limit: 65536K
Total Submissions: 3694   Accepted: 1936

Description

Arthur and his sister Caroll have been playing a game called Nim for some time now. Nim is played as follows:

  • The starting position has a number of heaps, all containing some, not necessarily equal, number of beads.
  • The players take turns chosing a heap and removing a positive number of beads from it.
  • The first player not able to make a move, loses.

Arthur and Caroll really enjoyed playing this simple game until they
recently learned an easy way to always be able to find the best move:

  • Xor
    the number of beads in the heaps in the current position (i.e. if we
    have 2, 4 and 7 the xor-sum will be 1 as 2 xor 4 xor 7 = 1).
  • If the xor-sum is 0, too bad, you will lose.
  • Otherwise, move such that the xor-sum becomes 0. This is always possible.

It is quite easy to convince oneself that this works. Consider these facts:

  • The player that takes the last bead wins.
  • After the winning player's last move the xor-sum will be 0.
  • The xor-sum will change after every move.

Which
means that if you make sure that the xor-sum always is 0 when you have
made your move, your opponent will never be able to win, and, thus, you
will win.

Understandibly it is no fun to play a game when both players know
how to play perfectly (ignorance is bliss). Fourtunately, Arthur and
Caroll soon came up with a similar game, S-Nim, that seemed to solve
this problem. Each player is now only allowed to remove a number of
beads in some predefined set S, e.g. if we have S = {2, 5} each player
is only allowed to remove 2 or 5 beads. Now it is not always possible to
make the xor-sum 0 and, thus, the strategy above is useless. Or is it?

your job is to write a program that determines if a position of
S-Nim is a losing or a winning position. A position is a winning
position if there is at least one move to a losing position. A position
is a losing position if there are no moves to a losing position. This
means, as expected, that a position with no legal moves is a losing
position.

Input

Input consists of a number of test cases.

For each test case: The first line contains a number k (0 < k ≤
100) describing the size of S, followed by k numbers si (0 < si ≤
10000) describing S. The second line contains a number m (0 < m ≤
100) describing the number of positions to evaluate. The next m lines
each contain a number l (0 < l ≤ 100) describing the number of heaps
and l numbers hi (0 ≤ hi ≤ 10000) describing the number of beads in the
heaps.

The last test case is followed by a 0 on a line of its own.

Output

For
each position: If the described position is a winning position print a
'W'.If the described position is a losing position print an 'L'.

Print a newline after each test case.

Sample Input

2 2 5
3
2 5 12
3 2 4 7
4 2 3 7 12
5 1 2 3 4 5
3
2 5 12
3 2 4 7
4 2 3 7 12
0

Sample Output

LWW
WWL

Source

【思路】

SG函数。

裸ti ,注意下sg和vis的大小就好了 :)

【代码】

 #include<cstdio>
#include<cstring>
#define FOR(a,b,c) for(int a=(b);a<(c);a++)
using namespace std; int n,m,a[],sg[]; int dfs(int x) {
if(sg[x]!=-) return sg[x];
if(!x) return sg[x]=;
int vis[]; //size of [si]
memset(vis,,sizeof(vis));
FOR(i,,n)
if(x>=a[i]) vis[dfs(x-a[i])]=;
for(int i=;;i++)
if(!vis[i]) return sg[x]=i;
} int main() {
while(scanf("%d",&n)== && n) {
FOR(i,,n) scanf("%d",&a[i]);
scanf("%d",&m);
memset(sg,-,sizeof(sg));
FOR(i,,m) {
int x,v,ans=;
scanf("%d",&x);
FOR(j,,x)
scanf("%d",&v) , ans^=dfs(v);
if(ans) printf("W");
else printf("L");
}
putchar('\n');
}
return ;
}

最新文章

  1. C# PPT 为形状设置三维效果
  2. vim 配置
  3. BZOJ 1093 [ZJOI2007] 最大半连通子图(强联通缩点+DP)
  4. 【php学习】时间函数
  5. C#操作office进行Excel图表创建,保存本地,word获取
  6. 关于解决 The processing instruction target matching &quot;[xX][mM][lL]&quot; is not allowed
  7. Demo学习: Dialogs Anonymous Callback
  8. onresize的定义方式
  9. string 与char* char[]之间的转换
  10. Python之Threading模块
  11. Get Docker CE for CentOS
  12. DDD「领域驱动设计」分层架构初探
  13. CF1119B Alyona and a Narrow Fridge
  14. Vue(二十五)打包后路径报错问题
  15. BOM 浏览器对象模型_window.navigator
  16. Luogu P2468 [SDOI2010]粟粟的书架
  17. aio,nio ,io 心得
  18. css3径向渐变
  19. 微信公众号支付(JSAPI)对接备忘
  20. 初识Unity Mesh

热门文章

  1. 关于C++和C#类型比较的相关内容
  2. SQL输出矩阵
  3. centos 彻底卸载mysql
  4. CoreAnimation4-隐式动画和显式动画
  5. AdaBoost原理,算法实现
  6. VS 2012中消失了的Create UnitTest
  7. html本地存储尝试
  8. jQuery源码整体结构(源码2.0.3)
  9. Jquery效果之固定不动的块
  10. JavaScript Iframe富文本编辑器中的光标定位