【codeforces 787C】Berzerk
【题目链接】:http://codeforces.com/contest/787/problem/C
【题意】
给你怪物一开始所在的位置;
然后两人轮流操作;
可以选择让这个怪物前进自己的集合里面所拥有的数字所代表的步数;
对于2..n这些怪物的起点以及谁先进行游戏这些信息;
让这个怪物到位置1的人赢
判断谁能赢,输,或者游戏一直循环下去
【题解】
设f[i][j]表示i先玩,然后怪物一开始的位置为j的结果;
则
//-2表示输,-1表示赢,0表示不确定
f[1][1]=f[2][1]=-2;
即如果谁面临了怪物到达了1这个位置这个状态,他就输了;
因为这表示对方已经完成游戏了;
这样就代表先手输了;
然后对于这些为-2的状态;
可以往前推前一个人的状态;
即
前一个人,他走一步(通过自己集合里面的步数)到达了-2的状态;
也就是说让对方面临了先手输的状态,本来你是先手,然后你走一步,对方就变成先手啦,那么对方面临了先手输的状态,那么你就赢了;
因此对于所有能够走到-2的状态;
置其状态为先手赢;
然后再去找那些;
无论用集合里面哪个元素走,都会让对方面临先手赢状态的状态;
这些状态,置它们为先手输;
因为它们无论怎么走,对方都能面对先手赢的状态;
然后对于其他的状态,都是不确定.
写个倒推就好;
具体看代码
【完整代码】
#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%lld",&x)
#define ref(x) scanf("%lf",&x)
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 7e3+100;
int k[3],n;
int s[3][N];
int g[3][N];
queue <pii> dl;
void in()
{
rei(n);
rep1(i,1,2)
{
rei(k[i]);
rep1(j,1,k[i])
rei(s[i][j]);
}
}
void get_ans()
{
dl.push(mp(1,1)),dl.push(mp(2,1));
g[1][1] = -2,g[2][1] = -2;
while (!dl.empty())
{
int f = dl.front().fi,x = dl.front().se;
int nex = 3-f;
dl.pop();
rep1(i,1,k[nex])
{
int y = x-s[nex][i];
if (y<=0)
y+=n;
if (g[f][x]==-2)
{
if (g[nex][y]!=-1)
{
g[nex][y] = -1;
dl.push(mp(nex,y));
}
}
else
{//g[f][x] = -1
if (g[nex][y]<0) continue;//如果已经确定了,就不用计数了
g[nex][y]++;//用来记录这个状态用集合里面的元素走一步会遇到多少个先手赢的状态,这里是直接在这个数组上计数,一数组两用
if (g[nex][y]==k[nex])//如果全都是先手赢,那么这个状态就是先手输
{
g[nex][y] = -2;
dl.push(mp(nex,y));
}
}
}
}
}
void o()
{
rep1(i,2,n)
{
if (g[1][i]==-2)
printf("Lose");
else
if (g[1][i]==-1)
printf("Win");
else
printf("Loop");
if (i==n)
puts("");
else
putchar(' ');
}
rep1(i,2,n)
{
if (g[2][i]==-2)
printf("Lose");
else
if (g[2][i]==-1)
printf("Win");
else
printf("Loop");
if (i==n)
puts("");
else
putchar(' ');
}
}
int main()
{
//freopen("F:\\rush.txt","r",stdin);
in();
get_ans();
o();
//printf("\n%.2lf sec \n", (double)clock() / CLOCKS_PER_SEC);
return 0;
}
【codeforces 787C】Berzerk的更多相关文章
- 【codeforces 415D】Mashmokh and ACM(普通dp)
[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...
- 【codeforces 707E】Garlands
[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...
- 【codeforces 707C】Pythagorean Triples
[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...
- 【codeforces 709D】Recover the String
[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...
- 【codeforces 709B】Checkpoints
[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...
- 【codeforces 709C】Letters Cyclic Shift
[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...
- 【Codeforces 429D】 Tricky Function
[题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ...
- 【Codeforces 670C】 Cinema
[题目链接] http://codeforces.com/contest/670/problem/C [算法] 离散化 [代码] #include<bits/stdc++.h> using ...
- 【codeforces 515D】Drazil and Tiles
[题目链接]:http://codeforces.com/contest/515/problem/D [题意] 给你一个n*m的格子; 然后让你用1*2的长方形去填格子的空缺; 如果有填满的方案且方案 ...
随机推荐
- 开源企业IM-免费企业即时通讯-ENTBOOST V2014.177 Windows版本号正式公布
ENTBOOST,VERSION 2014.177 LINUX 版本号公布.主要添加Android安卓手机开发接口.企业IM接口,JQUERY开发接口,PCclient部分BUG修正: 下版本号更新时 ...
- Redis实现Mybatis的二级缓存
一.Mybatis的缓存 通大多数ORM层框架一样,Mybatis自然也提供了对一级缓存和二级缓存的支持.一下是一级缓存和二级缓存的作用于和定义. 1.一级缓存是SqlSession级别的缓存.在操作 ...
- 大话Spark(8)-源码之DAGScheduler
DAGScheduler的主要作用有2个: 一.把job划分成多个Stage(Stage内部并行运行,整个作业按照Stage的顺序依次执行) 二.提交任务 以下分别介绍下DAGScheduler是如何 ...
- LibCurl HTTP部分详细介绍
目录索引: 一.LibCurl基本编程框架 二.一些基本的函数 三.curl_easy_setopt函数部分选项介绍 四.curl_easy_perform 函数说明(error 状态码) 五.lib ...
- C#判断操作系统类型
操作系统 PlatformID 主版本号 副版本号 Windows95 1 4 0 Windows98 1 4 10 WindowsMe 1 4 90 WindowsN ...
- C#+AE实现类似IDentify功能及对高亮显示相关接口的总结
kenika 原文C#+AE实现类似IDentify功能及对高亮显示相关接口的总结 ArcMap中的Identify功能是有目的查看要素(Feature)属性信息经常使用的工具.ArcMap中的Ide ...
- 浅谈java中异常抛出后代码是否会继续执行
问题 今天遇到一个问题,在下面的代码中,当抛出运行时异常后,后面的代码还会执行吗,是否需要在异常后面加上return语句呢? public void add(int index, E element) ...
- ios开发网络学习九:NSURLSessionDownloadTask实现大文件下载
一:NSURLSessionDownloadTask:实现文件下载:无法监听进度 #import "ViewController.h" @interface ViewControl ...
- 将String转化为Long,并将Long转化为Date 分类: B1_JAVA 2014-06-30 16:23 1249人阅读 评论(0) 收藏
package org.ljh.test.javaee; import java.text.SimpleDateFormat; import java.util.Date; public class ...
- php实现 句子逆序(需求才是最好的老师)
php实现 句子逆序(需求才是最好的老师) 一.总结 一句话总结:需求才是最好的老师. 1.str_split()和explode()的区别? explode — 使用一个字符串分割另一个字符串 3 ...