World of Darkraft(codeforces 138D)
题意:有一个 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)的更多相关文章
- (CodeForces - 5C)Longest Regular Bracket Sequence(dp+栈)(最长连续括号模板)
(CodeForces - 5C)Longest Regular Bracket Sequence time limit per test:2 seconds memory limit per tes ...
- Sorted Adjacent Differences(CodeForces - 1339B)【思维+贪心】
B - Sorted Adjacent Differences(CodeForces - 1339B) 题目链接 算法 思维+贪心 时间复杂度O(nlogn) 1.这道题的题意主要就是让你对一个数组进 ...
- (CodeForces 558C) CodeForces 558C
题目链接:http://codeforces.com/problemset/problem/558/C 题意:给出n个数,让你通过下面两种操作,把它们转换为同一个数.求最少的操作数. 1.ai = a ...
- [题解]Yet Another Subarray Problem-DP 、思维(codeforces 1197D)
题目链接:https://codeforces.com/problemset/problem/1197/D 题意: 给你一个序列,求一个子序列 a[l]~a[r] 使得该子序列的 sum(l,r)-k ...
- 【Codeforces】【图论】【数量】【哈密顿路径】Fake bullions (CodeForces - 804F)
题意 有n个黑帮(gang),每个黑帮有siz[i]个人,黑帮与黑帮之间有有向边,并形成了一个竞赛完全图(即去除方向后正好为一个无向完全图).在很多年前,有一些人参与了一次大型抢劫,参与抢劫的人都获得 ...
- 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 ...
- 【日常训练】Help Victoria the Wise(Codeforces 99C)
题意与分析 这题意思是这样的:在正方体的六面镶嵌给定颜色的宝石(相同颜色不区分),然后问最多有几种彼此不等价(即各种旋转过后看起来一致)的方案. 其实可以乱搞,因为范围只有720.求出全排列,然后每个 ...
- 【日常训练】Help Far Away Kingdom(Codeforces 99A)
题意与分析 题意很简单,但是注意到小数可能有一千位,作为一周java选手的我选择了java解决. 这里的分析会归纳一些必要的Java API:(待补) 代码 /* * ACM Code => c ...
- Palindrome Degree(CodeForces 7D)—— hash求回文
学了kmp之后又学了hash来搞字符串.这东西很巧妙,且听娓娓道来. 这题的题意是:一个字符串如果是回文的,那么k值加1,如果前一半的串也是回文,k值再加1,以此类推,算出其k值.打个比方abaaba ...
随机推荐
- Oracle 事务 锁
一. 事务 是一系列的数据库操作,是数据库应用的基本逻辑单位以及并发控制的基本单位.所谓的事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位. 要将有组语句作为事务考 ...
- 在mac下使用python抓取数据
2015已经过去,这是2016的第一篇博文! 祝大家新年快乐! 但是我还有好多期末考试! 还没开始复习,唉,一把辛酸泪! 最近看了一遍彦祖的文章叫做 iOS程序员如何使用Python写网路爬虫 所以自 ...
- for in 和 for of的区别详解
for in 和 for of 相对于大家肯定都不陌生,都是用来遍历属性的没错.那么先看下面的一个例子: 例1 const obj = { a: 1, b: 2, c: 3 } for (let i ...
- 【luogu题解】P1546 最短网络 Agri-Net
题目 约翰已经给他的农场安排了一条高速的网络线路,他想把这条线路共享给其他农场.为了用最小的消费,他想铺设最短的光纤去连接所有的农场. 你将得到一份各农场之间连接费用的列表,你必须找出能连接所有农场并 ...
- Apache 错误日志
配置文件中:httpd.conf ErrorLog "/usr/local/var/log/apache2/error_log1" CustomLog "/usr/loc ...
- goaccess实现实时监控
一.实现后台实时监控 goaccess -p /usr/local/etc/goaccess/goaccess.conf /var/log/nginx/access.log -a -o /usr/sh ...
- ATM-interface-user
from db import db_handlerfrom lib import common user_logger = common.get_logger('user') def login_in ...
- 5分钟带你快速理解Http协议
HTTP协议 什么是HTTP协议 HTTP(Hyper Text Transfer Protocol)协议又叫超文本传输协议,是建立在TCP/IP协议之上的用来传递数据的协议.它不涉及数据包的传递,主 ...
- javascript隐藏和显示元素以及清空textarea
当前希望写一个单选框,选中“paste”则显示粘贴框,选中“upload”则提示选择文件. 因为这两种情况只是显示不同,所以只需要用javascript来进行显示和隐藏. 最后的结果大概这样: 初始时 ...
- poj 3104 晾衣服问题 最大化最小值
题意:n件衣服各含有ai水分,自然干一分钟一个单位,放烘干机一分钟k个单位,问:最短时间? 思路: mid为最短时间 如果 a[i]-mid>0说明需要放入烘干机去烘干 烘干的时间为x 那么满 ...