题目大意

额,写来写去,我还是直接说抽象之后的题目大意吧:

有一个 r*2 的矩形,两个人轮流的在矩形上面减去一个 1*1 的小正方形,要求在减的过程中,不能使矩形“断开”,也就是说,如果一个人减去了 (i, 1) 这个矩形,那么,(i-1, 2), (i+1, 2), (i, 2) 这三个小正方形不能再被减去了,因为一旦减去它们中的一个,整个矩形就会被“剪断”

现在给你一个 r 和 n (1 ≤ r ≤ 100, 0 ≤ n ≤ r),表示有一个 r*2 矩形,已经有了 n 个位置被减去了,再给 n 个位置的坐标,题目保证开始的状态矩形不会被剪断.

现在问,对于当前的状态,先手是否必胜

做法分析

这题是博弈已经没得说了,而且,很明显是游戏的和的问题,必然是爆 sg 函数了

先来看看怎么表示状态:sg[len][x][y] 表示,有一个长度为 len 的矩形,它的 len*2 个小正方形都在,最左边的一个小正方形只能按照 x 的方式剪掉,最右边的一个小正方形只能按照 y 的方式剪掉,其中:x=1 或者 y=1 表示剪掉的是第一排的矩形,x=2 或者 y=2 表示剪掉的是第二排的矩形,x=0 或者 y=0 表示没有限制,即:可以剪掉第一排的也可以剪掉第二排的

那么,当 len=0 的时候,必然有 sg[0][x][y]=0,其中 0≤x≤2, 0≤y≤2

当 len=1 的时候,必然有 sg[1][1][2]=sg[1][2][1]=0, sg[1][1][1]=sg[1][2][2]=sg[1][0][x]=sg[1][x][0]=1,其中 0≤x≤2

根据状态的定义,当前状态的下一个子状态也很好确定,先记忆化搜索将 sg 函数暴力出来

然后,根据输入的矩形,将举行分解成若干个子矩形,每个子矩形都应该尽量大,这样,每个子矩形必然属于上面提到的的一个状态之一

现在的游戏就变成了很多个游戏的和了,求出这些子游戏的 sg 值的异或和 sum,如果 sum!=0,先手必胜,否则先手必败

参考代码

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>
#include <algorithm> using namespace std; const int N=; int sg[N][][];
struct data {
int id, val;
bool operator < (const data &T) const {
return id<T.id;
}
} A[N]; int GET_SG(int len, int x, int y) {
if(sg[len][x][y]!=-) return sg[len][x][y]; if(len==) return sg[len][x][y]=sg[len][y][x]=;
if(x>y) swap(x, y);
if(len== && x== && y==) return sg[len][x][y]=sg[len][y][x]=;
if(len==) return sg[len][x][y]=sg[len][y][x]=; bool vs[N];
memset(vs, , sizeof vs);
for(int len1=; len1<len; len1++) {
int len2=len--len1;
if(len1==) {
if(x==) {
vs[GET_SG(len2, , y)]=;
vs[GET_SG(len2, , y)]=;
}
else vs[GET_SG(len2, x, y)]=;
}
else if(len2==) {
if(y==) {
vs[GET_SG(len1, x, )]=;
vs[GET_SG(len1, x, )]=;
}
else vs[GET_SG(len1, x, y)]=;
}
else {
vs[GET_SG(len1, x, )^GET_SG(len2, , y)]=;
vs[GET_SG(len1, x, )^GET_SG(len2, , y)]=;
}
}
for(int i=; i<N; i++) if(!vs[i]) return sg[len][x][y]=sg[len][y][x]=i;
} int main() {
memset(sg, -, sizeof sg);
for(int i=; i<=; i++)
for(int j=; j<; j++)
for(int k=; k<; k++) if(sg[i][j][k]==-) GET_SG(i, j, k);
for(int r, n; scanf("%d%d", &r, &n)!=EOF; ) {
for(int i=; i<=n; i++) scanf("%d%d", &A[i].id, &A[i].val);
A[].id=, A[].val=, A[n+].id=r+, A[n+].val=;
n+=;
sort(A, A+n);
int sum=;
for(int i=; i<n; i++) sum^=sg[A[i].id-A[i-].id-][A[i-].val][A[i].val];
if(sum) printf("WIN\n");
else printf("LOSE\n");
}
return ;
}

C. More Reclamation

题目链接 & AC 通道

MemSQL start[c]up Round 2 - online version C. More Reclamation

MemSQL start[c]up Round 2 - online version C. More Reclamation(博弈)的更多相关文章

  1. MemSQL start[c]up Round 2 - online version(DP)

    只有小写字母 那>=2600的直接找单字母串长度大于等于100的就可以了 <2600 的dp找最长回文串 #include <iostream> #include<cst ...

  2. codeforces MemSQL start[c]up Round 2 - online version B 最长公共子系列

    题目链接:  http://codeforces.com/contest/335/problem/B 分析: 第一眼看上去串的长度为5*10^4, 冒似只能用O(n)的算法可解. 而这样的算法从来没见 ...

  3. MemSQL start[c]up Round 1.b

    二分查找题, 不知道用double的人,用LL果断错了... B. Stadium and Games time limit per test 1 second memory limit per te ...

  4. MemSQL start[c]up Round 1 B题

    题目链接 http://codeforces.com/contest/325/problem/B 第一遍写了暴搜,果断TLE 然后上了二分,结果120组数据只有第40组过不了,我就写了奇怪的东西... ...

  5. MemSQL start[c]up Round 1.E

    完全的乱搞题啊... 被坑的要死. 拿到题目就觉得是规律题加构造题, 然后找了了几个小时无果,只知道n为奇数的时候是一定无解的,然后当n为偶数的时候可能有很多解,但是如果乱选择的话,很有可能形成无解的 ...

  6. Codeforces Round #459 (Div. 2) D. MADMAX DFS+博弈

    D. MADMAX time limit per test 1 second memory limit per test 256 megabytes input standard input outp ...

  7. Codeforces Round #651 (Div. 2) C. Number Game (博弈,数学)

    题意:对于正整数\(n\),每次可以选择使它变为\(n-1\)或者\(n/t\) (\(n\ mod\ t=0\)且\(t\)为奇数),当\(n=1\)时便不可以再取,问先手赢还是后手赢. 题解:首先 ...

  8. JAVA入门[14]-Spring MVC AOP

    一.基本概念 1.AOP简介 DI能够让相互协作的软件组件保持松散耦合:而面向切面编程(aspect-oriented programming,AOP)允许你把遍布应用各处的功能分离出来形成可重用的组 ...

  9. 【概念】SVG(1)

    ok,我们讲讲svg 学习前提:懂HTML和基本的XML SVG简介: 1.SVG全称Scable Vector Graphic,可伸缩的矢量图 2.SVG用于定义针对于Web的基于矢量的图形 3.S ...

随机推荐

  1. jenkins 插件Copy Artifacts + Artifacts to copy

    问题及遇到的错误: Unable to access upstream artifacts area /var/lib/jenkins/jobs/PROJECTNAME-Master-Branch/b ...

  2. 地理围栏算法解析(Geo-fencing)

    地理围栏算法解析 http://www.cnblogs.com/LBSer/p/4471742.html 地理围栏(Geo-fencing)是LBS的一种应用,就是用一个虚拟的栅栏围出一个虚拟地理边界 ...

  3. tab切换的两种方法

    方法一.主要使用了传递参数的思想,把循环变量不能使用转换了一下<!DOCTYPE html><html lang="en"><head> < ...

  4. gulp+Babel 搭建ES6环境

    Gulp是什么? Gulp是一个工作流的构建系统,开发者可以使用它在网站开发过程中自动执行常见任务.Gulp是基于Node.js构建的,因此Gulp源文件和你用来定义任务的Gulp文件都被写进了Jav ...

  5. ubuntu 12.04 "系统的网络服务与此版本的网络管理器不兼容

    ubuntu 12.04 "系统的网络服务与此版本的网络管理器不兼容“ 2013-05-10 21:18 2271人阅读 评论(0) 收藏 举报 今天上午在实验室一顿乱整,不知道整坏了什么, ...

  6. emoji表情引发的JNI崩溃

    今天突然接到客服那边的反馈说,有玩家反馈进游戏后不久就崩溃了,我先是怀疑网络问题,因为一连接聊天成功后就挂了.之后用logcat抓日志,发现挂在jni那里了 JNI DETECTED ERROR IN ...

  7. 小白学数据分析----->留存率与运营活动分析_I

    有关留存率的事情最近扯得比较多,因为在分析数据的时候,越发觉得,分析一定是要来解决问题的,留存率不知何时突然变得流行了,在此讨论留存率倒不是因为流行,而是觉得以留存率为核心,的确是可以帮助我们解决不少 ...

  8. Swift入门篇-基本类型(2)

    现在我也在学习Swift语言,常常去逛很多苹果社区和论坛,看到了圈子很多奇怪的现象,发现很多人都赶忙去翻译 Swift书籍 和 发布Swift的视频 .他们这种对新知识的探索精神我本人是很佩服的.但是 ...

  9. spring boot注解之@Scheduled定时任务实现

    java实现定时任务一般使用timer,或者使用quartz组件.现在在spring boot提供了更加方便的实现方式. spring boot已经集成了定时任务.使用@Secheduled注解. @ ...

  10. 【Vegas原创】Mysql绿色版安装方法

    所谓的绿色版,就是没有installer的MySQL,完全需要靠人工来操作,好处是,重装系统后,只要再做一次本次配置,即可使用. 具体操作方法: 1,设置系统环境变量, 在Path中添加 D:\mys ...