Codeforces 138D World of Darkraft(Multi-Nim)
【题目链接】 http://codeforces.com/problemset/problem/138/D
【题目大意】
H*W的棋盘中每个点都是L、R、X三者之一,两人轮流选一个点,
若为L则向左下和右上发射激光,R向右下和左上发射,
X则相当于LR的组合——同时向四个方向发射。激光所至的点会被摧毁,
只有已摧毁的点或棋盘边界才会挡住激光。
若在某回合开始时所有点都被摧毁,则该人失败。问先手是否有必胜策略?
【题解】
我们根据激光将棋盘切成不同的不同的部分,
将几个子游戏的sg异或起来作为整个游戏的sg值,
以为激光是斜着切的所以我们把棋盘转一转方便处理,
此外棋盘的奇偶格子是互不干扰的因此我们分开计算其sg值并异或起来判断答案
【代码】
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
char mp[30][30];
int sg[50][50][50][50][2],n,m;
int SG(int x1,int x2,int y1,int y2,int k){
int &ret=sg[x1][x2][y1][y2][k];
if(ret!=-1)return ret;
char s[60]={0};
for(int y=0;y<n;y++){
for(int x=0;x<m;x++){
if(((x+y)&1)==k){
int _x=y+x,_y=y-x+m;
if(x1<=_x&&_x<x2&&y1<=_y&&_y<y2){
char c=mp[y][x];
int g=0;
if(c=='L')g=SG(x1,_x,y1,y2,k)^SG(_x+1,x2,y1,y2,k);
if(c=='R')g=SG(x1,x2,y1,_y,k)^SG(x1,x2,_y+1,y2,k);
if(c=='X'){
g=SG(x1,_x,y1,_y,k);
g^=SG(x1,_x,_y+1,y2,k);
g^=SG(_x+1,x2,y1,_y,k);
g^=SG(_x+1,x2,_y+1,y2,k);
}s[g]=1;
}
}
}
}while(s[++ret]);
return ret;
}
int main(){
while(~scanf("%d%d",&n,&m)){
for(int i=0;i<n;i++)scanf("%s",mp[i]);
memset(sg,-1,sizeof(sg));
puts(SG(0,n+m,0,n+m,0)^SG(0,n+m,0,n+m,1)?"WIN":"LOSE");
}return 0;
}
Codeforces 138D World of Darkraft(Multi-Nim)的更多相关文章
- HDU 5795 A Simple Nim(简单Nim)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- CodeForces 450B Jzzhu and Sequences (矩阵优化)
CodeForces 450B Jzzhu and Sequences (矩阵优化) Description Jzzhu has invented a kind of sequences, they ...
- codeforces gym #102082C Emergency Evacuation(贪心Orz)
题目链接: https://codeforces.com/gym/102082 题意: 在一个客车里面有$r$排座位,每排座位有$2s$个座位,中间一条走廊 有$p$个人在车内,求出所有人走出客车的最 ...
- Codeforces Gym100502H:Clock Pictures(KMP算法)
http://codeforces.com/gym/100502/attachments 题意:有两个时钟上面有n个指针,给出的数字代表指针的角度.问能否在某一时刻使得两个时钟的指针重合. 思路:容易 ...
- Codeforces 758C:Unfair Poll(思维+模拟)
http://codeforces.com/problemset/problem/758/C 题意:教室里有n列m排,老师上课点名从第一列第一排开始往后点,直到点到第一列第m排,就从第二列第一排开始点 ...
- Codeforces 639E - Bear and Paradox(二分+贪心)
Codeforces 题目传送门 & 洛谷题目传送门 原来 jxd 作业里也有我会做的题 i 了 i 了 首先这种题目的套路就是先考虑对于一个固定的 \(c\),怎样求出得分最高的策略,而类似 ...
- 多重网格法简介(Multi Grid)
原文链接 多重网格法是一种用于求解方程组的方法,可用于插值.解微分方程等. 从专业角度讲多重网格法实际上是一种多分辨率的算法,由于直接在高分辨率(用于求解的间隔小)上进行求解时对于低频部分收敛较慢,与 ...
- CodeForces 342A Xenia and Divisors (水题)
题意:给定 n 个数(小于等于7),让你把它分成 m 组,每组有三个数,且满足,a < b < c,并且 a 能整除 b,b 能整除 c. 析:对于这个题,因为题目说了是不大于7的,那么一 ...
- Codeforces Round #316 (Div. 2) (ABC题)
A - Elections 题意: 每一场城市选举的结果,第一关键字是票数(降序),第二关键字是序号(升序),第一位获得胜利. 最后的选举结果,第一关键字是获胜城市数(降序),第二关键字是序号(升序) ...
随机推荐
- JAVA int自动装箱
int 转 Integer: Integer int127_1 = 127; Integer int127_2 = 127; System.out.println("int127_1 == ...
- Codeforces Round #520 (Div. 2) B. Math
B. Math time limit per test:1 second memory limit per test:256 megabytes Description: JATC's math te ...
- 编写一个 Chrome 浏览器扩展程序
浏览器扩展允许我们编写程序来实现对浏览器元素(书签.导航等)以及对网页元素的交互, 甚至从 web 服务器获取数据,以 Chrome 浏览器扩展为例,扩展文件包括: 一个manifest文件(主文件, ...
- Oop分析方法
为了实现Oop,这个我已经在一个前端的js项目中实现了Oop,过后总结:对于js这种动态语言,可以在运行时动态组件对象的属性和方法这种,解释型的语言来讲,真的是OOP,如果不存在关系数据库,仅仅是从后 ...
- 【洛谷 P1651】 塔 (差值DP)
题目链接 题意:\(n\)个木块放到两个塔里,每个木块可放可不放,使得两塔高度相同且高度最大,求最大高度. 这个差值\(DP\)的思维难度还是很大的,没想出来,我就打了一个\(dfs\)骗了好像\(2 ...
- CentOS 7 主机加固手册-中
CentOS 7 主机加固手册-上 CentOS 7 主机加固手册-中 CentOS 7 主机加固手册-下 0x0c 设置/boot/grub2/grub.cfg权限 Set grub.conf ...
- MongoDB安装成为Windows服务
使用以下命令将MongoDB安装成为Windows服务.笔者的MongoDB目录为C:\Program Files\MongoDB\Server\3.6\bin 切换到C:\Program Files ...
- Linux 下面adb命令的使用
平板或者android手机使用adb是非常方便的.接下来我就介绍下adb使用以及一些常用的命令. 1,连接 用adb连接线,一端接PC的USB中,一端接平板或手机的adb口,当然得确保线没有问题,而且 ...
- HTTP===通用首部字段的各种指令解释
Cache-Control 通过指定首部字段 Cache-Control 的指令,就能操作缓存的工作机制. 指令的参数是可选的,多个指令之间通过“,”分隔.首部字段 Cache-Control 的指令 ...
- 原型 Boolean String Math Date知识点
原型 1.定义 每一个对象都有原型 原型仍然是一个对象 模拟实现面向对象的继承性 2.原型链 对象的原型还有原型 对象除了可以使用自有属性还可以继承原型上的属性 3.获取原型 对象.__proto__ ...