题意:有一个 n × m 的棋盘,每个点上标记了 L; R; X 中的一个

每次能选择一个没有被攻击过的点 (i; j),从这个点开始发射线,射线形状为:

1. 若字符是 L,向左下角和右上角发,遇到被攻击过的点就停下来

2. 若字符是 R,向左上角和右下角发,遇到被攻击过的点就停下来

3. 若字符是 X,向左小左上右下右上发,遇到被攻击过的点停下来

问先手是否必胜, n; m ≤ 20

/*
首先可以根据激光的性质,把图进行奇偶划分,然后就变成了两个子问题。
当出现一道激光时,这个游戏就变成了2个或4个完全等价的游戏,可以根据这个特点设计SG函数。
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#define N 50
using namespace std;
int n,m,dp[N][N][N][N][];
char map[N][N];
int dfs(int min_x,int max_x,int min_y,int max_y,int op){
int ret=dp[min_x][max_x][min_y][max_y][op];
if(ret!=-) return ret;
char s[N]={};
for(int i=;i<n;i++)
for(int j=;j<m;j++)
if((i+j&)==op){
int x=i+j,y=i-j+m;
if(x>=min_x&&x<max_x&&y>=min_y&&y<max_y){
int g=;
if(map[i][j]=='L')
g=dfs(min_x,x,min_y,max_y,op)^dfs(x+,max_x,min_y,max_y,op);
if(map[i][j]=='R')
g=dfs(min_x,max_x,min_y,y,op)^dfs(min_x,max_x,y+,max_y,op);
if(map[i][j]=='X')
g=dfs(min_x,x,min_y,y,op)^dfs(min_x,x,y+,max_y,op)
^dfs(x+,max_x,min_y,y,op)^dfs(x+,max_x,y+,max_y,op);
s[g]=;
}
}
while(s[++ret]);
dp[min_x][max_x][min_y][max_y][op]=ret;
return ret;
}
int main(){
memset(dp,-,sizeof(dp));
scanf("%d%d",&n,&m);
for(int i=;i<n;i++) scanf("%s",map[i]);
int t=dfs(,n+m,,n+m,)^dfs(,n+m,,n+m,);
if(t) printf("WIN");
else printf("LOSE");
return ;
}

World of Darkraft(codeforces 138D)的更多相关文章

  1. (CodeForces - 5C)Longest Regular Bracket Sequence(dp+栈)(最长连续括号模板)

    (CodeForces - 5C)Longest Regular Bracket Sequence time limit per test:2 seconds memory limit per tes ...

  2. Sorted Adjacent Differences(CodeForces - 1339B)【思维+贪心】

    B - Sorted Adjacent Differences(CodeForces - 1339B) 题目链接 算法 思维+贪心 时间复杂度O(nlogn) 1.这道题的题意主要就是让你对一个数组进 ...

  3. (CodeForces 558C) CodeForces 558C

    题目链接:http://codeforces.com/problemset/problem/558/C 题意:给出n个数,让你通过下面两种操作,把它们转换为同一个数.求最少的操作数. 1.ai = a ...

  4. [题解]Yet Another Subarray Problem-DP 、思维(codeforces 1197D)

    题目链接:https://codeforces.com/problemset/problem/1197/D 题意: 给你一个序列,求一个子序列 a[l]~a[r] 使得该子序列的 sum(l,r)-k ...

  5. 【Codeforces】【图论】【数量】【哈密顿路径】Fake bullions (CodeForces - 804F)

    题意 有n个黑帮(gang),每个黑帮有siz[i]个人,黑帮与黑帮之间有有向边,并形成了一个竞赛完全图(即去除方向后正好为一个无向完全图).在很多年前,有一些人参与了一次大型抢劫,参与抢劫的人都获得 ...

  6. Maximum Sum of Digits(CodeForces 1060B)

    Description You are given a positive integer nn. Let S(x) be sum of digits in base 10 representation ...

  7. 【日常训练】Help Victoria the Wise(Codeforces 99C)

    题意与分析 这题意思是这样的:在正方体的六面镶嵌给定颜色的宝石(相同颜色不区分),然后问最多有几种彼此不等价(即各种旋转过后看起来一致)的方案. 其实可以乱搞,因为范围只有720.求出全排列,然后每个 ...

  8. 【日常训练】Help Far Away Kingdom(Codeforces 99A)

    题意与分析 题意很简单,但是注意到小数可能有一千位,作为一周java选手的我选择了java解决. 这里的分析会归纳一些必要的Java API:(待补) 代码 /* * ACM Code => c ...

  9. Palindrome Degree(CodeForces 7D)—— hash求回文

    学了kmp之后又学了hash来搞字符串.这东西很巧妙,且听娓娓道来. 这题的题意是:一个字符串如果是回文的,那么k值加1,如果前一半的串也是回文,k值再加1,以此类推,算出其k值.打个比方abaaba ...

随机推荐

  1. IPV6验证正则表达式

    验证ipv6的正则表达式: 例:fe80::ec61:c1d1:9827:82be%13 \s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9 ...

  2. SummerVocation_Learning--java的线程死锁

    public class Test_DeadLock implements Runnable { ; static Object o1 = new Object(),o2 = new Object() ...

  3. 洛谷P1111修复公路并查集改

    看了他们的题解感觉很震惊,为什么要用kruskal,这题要用到最小生成树吗??? 38行短短的程序就可以了,我觉得学习不是一种套用,套自己学的,而且题解很大一部分都是kruskal. 个人认为自己的程 ...

  4. 数据结构(C语言)分享笔记:数据结构的逻辑层次、存储层次

    [1] 严格意义上数据结构的概念 数据结构,一个简单的定义:相互之间存在一种或多种特定关系的数据元素的集合.即:数据结构 = 元素集合 + 元素间关系的集合 . 在讨论数据结构时,可以基于两个不同的层 ...

  5. struts2、hibernate的知识点

    以下内容是我在复习struts2.hibernate和spring的时候记下得到,部分书上找不到的内容来自网络 以下是网络部分的原文网站: http://blog.csdn.net/frankaqi/ ...

  6. MySQL 时间戳与日期互相转换

    MySQL 时间戳与日期互相转换 1.时间戳转换成日期 函数:FROM_UNIXTIME() ,'%Y年%m月%d日') 结果为:2015年04月15日 2.把日期转换为时间戳,和 FROM_UNIX ...

  7. Linux 服务器用户权限管理改造方案与实施项目

    Linux 服务器用户权限管理改造方案与实施项目 在了解公司业务流程后,提出权限整改方案改进公司超级权限root泛滥的现状. 我首先撰写方案后,给boss看,取得boss的支持后,召集大家开会讨论. ...

  8. python之格式化

    python有两种方式可以格式化一种是用%s,一种使用format(2.6)进入的,从下面的代码可以看出,效果差不多. name = 'edward' age = 27 print("My ...

  9. Jack Straws POJ - 1127 (简单几何计算 + 并查集)

    In the game of Jack Straws, a number of plastic or wooden "straws" are dumped on the table ...

  10. MySQL的增、删、查、改操作命令

    MySQL的增.删.查.改操作命令: 一.修改mysql数据库密码 格式:mysqladmin -u用户名 -p旧密码 password 新密码. 二.查看 查看多少个数据库:注意 后面带s #查看 ...