题目描述

http://www.lydsy.com/JudgeOnline/upload/Noi2017D2.pdf

题解

如果说没有x的话,那么每一局只能有两种选择,可以描述为是/非,每条限制也可以描述是x即y。

那么这就是一道经典的2-SAT问题。

现在有了x的限制,但是观察到x的数目很少最多只有8,所以我们可以考虑枚举限制。

注意到其他的地方有两种情况是因为有一种情况被ban了,所以我们考虑枚举2^x枚举该局禁哪个,因为禁A和禁B已经可以包含所有的情况,所以就不用禁C了。

仅为有ban的存在,所以我们在处理限制的时候要注意,如果某个位置连向的位置被ban了,那么直接连x->x‘表示x不合法。

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#define M 100002
#define N 50002
using namespace std;
char s[N],ss[];
int head[M],st[M],top,low[M],dfn[M],tot,co[M],num,ban[N],jin[N],n;
bool vis[M];
inline int rd(){
int x=;char c=getchar();bool f=;
while(!isdigit(c)){if(c=='-')f=;c=getchar();}
while(isdigit(c)){x=(x<<)+(x<<)+(c^);c=getchar();}
return f?-x:x;
}
struct node{
int x,y,xx,yy;
}b[M];
struct edge{int n,to;}e[M<<];
inline void add(int u,int v){e[++tot].n=head[u];e[tot].to=v;head[u]=tot;}
void tarjan(int u){
vis[u]=;st[++top]=u;low[u]=dfn[u]=++dfn[];
for(int i=head[u];i;i=e[i].n){
int v=e[i].to;
if(!dfn[v]){
tarjan(v);
low[u]=min(low[u],low[v]);
}
else if(vis[v])low[u]=min(low[u],dfn[v]);
}
if(dfn[u]==low[u]){
++num;int x;
do{
x=st[top];
vis[x]=;
co[x]=num;
top--;
}
while(x!=u);
}
}
int main(){
n=rd();int d=rd();
scanf("%s",s+);
for(int i=;i<=n;++i){
if(s[i]=='x')jin[++jin[]]=i;
else if(s[i]=='a')ban[i]=;
else ban[i]=;
s[i]-='a';
}
int m=rd();
for(int i=;i<=m;++i){
b[i].x=rd();scanf("%s",ss);b[i].xx=ss[]-'A';
b[i].y=rd();scanf("%s",ss);b[i].yy=ss[]-'A';
}
for(int i=;i<(<<d);++i){
for(int j=;j<=jin[];++j){
int x=(i&(<<j-))!=;
if(x)s[jin[j]]=,ban[jin[j]]=;
else s[jin[j]]=,ban[jin[j]]=;
}
memset(head,,sizeof(head));tot=;
for(int j=;j<=m;++j){
if(s[b[j].x]==b[j].xx)continue;
int nowx,nowy,antix,antiy;
nowx=(b[j].xx==ban[b[j].x])?b[j].x:b[j].x+n;antix=nowx<=n?nowx+n:nowx-n;
if(s[b[j].y]==b[j].yy){
add(nowx,antix);continue;
}
nowy=(b[j].yy==ban[b[j].y])?b[j].y:b[j].y+n;antiy=nowy<=n?nowy+n:nowy-n;
add(nowx,nowy);
add(antiy,antix);
}
memset(dfn,,sizeof(dfn));num=;
for(int j=;j<=n*;++j)if(!dfn[j])tarjan(j);
bool ta=;
for(int j=;j<=n;++j)if(co[j]==co[j+n]){ta=;break;}
if(ta)continue;
for(int j=;j<=n;++j)if(co[j]<co[j+n]){
if(ban[j]==)printf("B");
else printf("A");
}
else{
if(ban[j]==)printf("C");
else if(s[j]==)printf("C");else printf("B");
}
return ;
}
printf("-1");
return ;
}

[NOI2017]游戏的更多相关文章

  1. P3825 [NOI2017]游戏

    题目 P3825 [NOI2017]游戏 做法 \(x\)地图外的地图好做,模型:\((x,y)\)必须同时选\(x \rightarrow y,y^\prime \rightarrow x^\pri ...

  2. 【BZOJ4945】[Noi2017]游戏 2-SAT

    [BZOJ4945][Noi2017]游戏 题目描述 题解:2-SAT学艺不精啊! 这题一打眼看上去是个3-SAT?哎?3-SAT不是NPC吗?哎?这题x怎么只有8个?暴力走起! 因为x要么不是A要么 ...

  3. [Luogu P3825] [NOI2017] 游戏 (2-SAT)

    [Luogu P3825] [NOI2017] 游戏 (2-SAT) 题面 题面较长,略 分析 看到这些约束,应该想到这是类似2-SAT的问题.但是x地图很麻烦,因为k-SAT问题在k>2的时候 ...

  4. bzoj3825 NOI2017 游戏

    题目背景 狂野飙车是小 L 最喜欢的游戏.与其他业余玩家不同的是,小 L 在玩游戏之余,还精于研究游戏的设计,因此他有着与众不同的游戏策略. 题目描述 小 L 计划进行nn 场游戏,每场游戏使用一张地 ...

  5. [NOI2017]游戏(2-SAT)

    这是约半年前写的题解了,就搬过来吧 感觉这是NOI2017最水的一题(当然我还是不会2333),因为是一道裸的2-SAT.我就是看着这道题学的2-SAT 算法一:暴力枚举.对于abc二进制枚举,对于x ...

  6. NOI2017 [NOI2017]游戏 【2-sat】

    题目 题目背景 狂野飙车是小 L 最喜欢的游戏.与其他业余玩家不同的是,小 L 在玩游戏之余,还精于研究游戏的设计,因此他有着与众不同的游戏策略. 题目描述 小 L 计划进行nn 场游戏,每场游戏使用 ...

  7. bzoj 4945: [Noi2017]游戏

    Description Solution 首先我们发现一个位置如果不是 \('x'\),那么就只有两种选择 而 \('x'\) 的个数小于等于 \(8\),直接枚举是哪个就好了 然后就是 \(2-sa ...

  8. 洛谷3825 [NOI2017]游戏 2-sat

    原文链接http://www.cnblogs.com/zhouzhendong/p/8146041.html 题目传送门 - 洛谷3825 题解 我们考虑到地图中x的个数很少,最多只有8个. 所以我们 ...

  9. Luogu3825 NOI2017 游戏 2-SAT

    传送门 第一眼看上去似乎是一个3-SAT问题 然而\(d \leq 8\)给我们的信息就是:暴力枚举 枚举\(x\)型地图变成\(a\)型地图还是\(b\)型地图(实际上不要枚举\(c\),因为\(a ...

随机推荐

  1. 部署ionic开发环境

    (1)安装Node.js 首先您需要安装 Node.js,后续会使用到其中的 NPM 工具. (2)安装JDK 需要安装JDK,官网下载安装.命令窗口中输入 java -Xmx2048m -versi ...

  2. vue 使用定时器setInterval

    来自:https://www.jianshu.com/p/180957762852 侵删 beforeMount() { //车辆进出设置定时器,每3秒刷新一次 var self = this; cl ...

  3. 第十二课 CSS基本选择器 css学习2

    基础选择器一.标签选择器(元素选择器)标签选择器是指用HTML标签名称作为选择器,按标签名称分类语法:标签名{属性1:属性值1;属性2:属性值2;属性3:属性值3;} 二.类选择器1.类选择器使用&q ...

  4. java:编程比赛中有用的方法整理(一)数组

    我曾经参加过几次编程比赛,但是当时用的是c语言,现在学习了java,打算专攻java组,故以此整理. 数组无论在哪里都必不可少. 一.数组的拷贝: 使用Arrays类的copyOf方法: 1.将一个数 ...

  5. appium入门元素识别参考

    https://www.cnblogs.com/miniren/p/7365885.html#top

  6. SQL优化小技巧

    我们要做到不但会写SQL,还要做到写出性能优良的SQL语句. 1.使用表的别名(Alias): 当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来,就可以减少解析 ...

  7. RocketMQ三主三从二命名服务平滑版本升级实操

    ​本文介绍本次进行RocketMQ平滑过渡升级的实际操作 前文已经介绍过了升级基本原理,主要思想就是先升级NameSrv(命名服务)然后在升级broker节点.broker节点先升级master节点然 ...

  8. git 同步远程分支

    1. 同步远程分支到本地 git fetch 2. 查看本地分支 git branch *dev //当前分支 master test 3.切换分支 git checkout master // 切换 ...

  9. 深入学习:Windows下Git新手教程(上)

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/huangyabin001/article/details/35557231 一,安装Git: 1.1 ...

  10. MySQL存储引擎InnoDB与MyISAM的区别

    一.比较 事务:InnoDB是事务型的,可以使用Commit和Rollback语句. 并发:MyISAM只支持表级锁,InnoDB还支持行级锁. 外键:InnoDB支持外键. 备份:InnoDB支持在 ...