问题描述

LG3825

BZOJ4945

LOJ2305


题解

发现对于每个地图,如果没有\(A,B,C\)地图不可以使用\(a,b,c\),就是一个\(\mathrm{3-SAT}\)问题。

有了这个限制之后,\(A,B,C\)地图就变为了\(\mathrm{2-SAT}\)问题,但是\(x\)地图还是\(\mathrm{3-SAT}\)

因为\(\mathrm{k-SAT}(3 \le k)\)是一个\(\mathrm{NP}\)完全问题,观察到\(d \le 8\),于是直接爆搜即可。

爆搜出每个\(x\)的状态,\(\mathrm{2-SAT}\)即可。


\(\mathrm{Code}\)

#include<bits/stdc++.h>
using namespace std; template <typename Tp>
void read(Tp &x){
x=0;char ch=1;int fh;
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-'){
fh=-1;ch=getchar();
}
else fh=1;
while(ch>='0'&&ch<='9'){
x=(x<<1)+(x<<3)+ch-'0';
ch=getchar();
}
x*=fh;
} const int maxn=100000+7;
const int maxm=200000+7; int n,m,d; int Head[maxn],Next[maxm],to[maxm],tot;
int pic[maxn],all[maxn],cot; struct node{
int x,xx,y,yy;
}limt[maxm]; void add(int x,int y){
to[++tot]=y,Next[tot]=Head[x],Head[x]=tot;
} void fr_contest(int &x){
char ch=1;
while(ch!='x'&&ch!='a'&&ch!='b'&&ch!='c') ch=getchar();
if(ch=='x') x=4;
else if(ch=='a') x=1;
else if(ch=='b') x=2;
else x=3;
} void fr_limit(int &x){
char ch=1;
while(ch!='A'&&ch!='B'&&ch!='C') ch=getchar();
if(ch=='A') x=1;
else if(ch=='B') x=2;
else x=3;
} bool ins[maxn];
int sta[maxn],top,bel[maxn],cnt;
int dfn[maxn],low[maxn],ind; void tarjan(int x){
dfn[x]=low[x]=++ind;ins[x]=1,sta[++top]=x;
for(int i=Head[x];i;i=Next[i]){
int y=to[i];
if(dfn[y]){
if(ins[y]) low[x]=min(low[x],dfn[y]);
}
else{
tarjan(y);
low[x]=min(low[x],low[y]);
}
}
if(dfn[x]==low[x]){
++cnt;
while(sta[top]!=x){
bel[sta[top]]=cnt,ins[sta[top]]=0,top--;
}
bel[x]=cnt,ins[x]=0,top--;
}
} int id[maxn][4]; int opp(int x){
if(x>n) return x-n;
return x+n;
} void solve(){
memset(Head,0,sizeof(Head));memset(Next,0,sizeof(Next));
memset(dfn,0,sizeof(dfn));memset(low,0,sizeof(low));
tot=top=cnt=ind=0;memset(ins,0,sizeof(ins));memset(bel,0,sizeof(bel));
for(int i=1;i<=m;i++){
if(pic[limt[i].x]==limt[i].xx) continue;
if(pic[limt[i].y]==limt[i].yy){
add(id[limt[i].x][limt[i].xx],opp(id[limt[i].x][limt[i].xx]));
}
else{
add(id[limt[i].x][limt[i].xx],id[limt[i].y][limt[i].yy]);
add(opp(id[limt[i].y][limt[i].yy]),opp(id[limt[i].x][limt[i].xx]));
}
}
for(int i=1;i<=2*n;i++){
if(!dfn[i]) tarjan(i);
}
// for(int i=1;i<=n;i++){
// printf("node %d:%d %d %d\n",i,id[i][1],id[i][2],id[i][3]);
// }
for(int i=1;i<=n;i++){
if(bel[i]==bel[i+n]) return;
}
for(int i=1;i<=n;i++){
if(bel[i]<bel[i+n]){
if(pic[i]==1) printf("B");
else printf("A");
}
else{
if(pic[i]==1||pic[i]==2) printf("C");
else printf("B");
}
}
exit(0);
} void dfs(int step){
if(step==d+1){
solve();return;
}
int k=all[step];
pic[k]=1,id[k][2]=k,id[k][3]=k+n;
dfs(step+1);
pic[k]=2,id[k][1]=k,id[k][3]=k+n;
dfs(step+1);
pic[k]=4;
} int main(){
#ifndef ONLINE_JUDGE
freopen("game.in","r",stdin);
#endif
read(n);read(d);
for(int i=1;i<=n;i++){
fr_contest(pic[i]);
if(pic[i]==4){
all[++cot]=i;
}
if(pic[i]==1){
id[i][2]=i,id[i][3]=i+n;
}
else if(pic[i]==2){
id[i][1]=i,id[i][3]=i+n;
}
else if(pic[i]==3){
id[i][1]=i,id[i][2]=i+n;
}
}
read(m);
for(int i=1;i<=m;i++){
read(limt[i].x);fr_limit(limt[i].xx);
read(limt[i].y);fr_limit(limt[i].yy);
}
dfs(1);
printf("-1");
return 0;
}

LG3825/BZOJ4945/LOJ2305 「NOI2017」游戏 dfs+2-SAT的更多相关文章

  1. LOJ2305 「NOI2017」游戏

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

  2. 「NOI2017」游戏

    「NOI2017」游戏 题目描述 小 L 计划进行 \(n\) 场游戏,每场游戏使用一张地图,小 L 会选择一辆车在该地图上完成游戏. 小 L 的赛车有三辆,分别用大写字母 \(A\).\(B\).\ ...

  3. loj #2305. 「NOI2017」游戏

    #2305. 「NOI2017」游戏 题目描述 小 L 计划进行 nnn 场游戏,每场游戏使用一张地图,小 L 会选择一辆车在该地图上完成游戏. 小 L 的赛车有三辆,分别用大写字母 AAA.BBB. ...

  4. LOJ_2305_「NOI2017」游戏 _2-sat

    LOJ_2305_「NOI2017」游戏 _2-sat 题意: 给你一个长度为n的字符串S,其中第i个字符为a表示第i个地图只能用B,C两种赛车,为b表示第i个地图只能用A,C两种赛车,为c表示第i个 ...

  5. 「NOI2017」游戏 解题报告

    「NOI2017」游戏 \(d\)这么小,你考虑直接对\(d\)个东西暴力 枚举\(x\)为\(a\)或\(b\)(\(c\)就不用了,因为\(a,b\)已经包含\(c\))了,剩下的就是个\(2-s ...

  6. 【LOJ】 #2305. 「NOI2017」游戏

    题解 枚举x所在的地图的颜色,然后2-SAT建边 如果v所在的地图刚好是不能选的,那么u这边只能选另一种颜色 否则就是u的颜色到v的颜色 v的另一种颜色到u的另一种颜色 代码 #include < ...

  7. loj#2305. 「NOI2017」游戏 2-sat

    链接 https://loj.ac/problem/2305 https://www.luogu.org/problemnew/show/P3825 思路 3-sat神马的就不要想了,NP问题 除去x ...

  8. 「HNOI2018」游戏

    「HNOI2018」游戏 解题思路 首先没有锁上的门可以缩点缩掉,然后对于一扇锁上的门,如果钥匙在左边,那么右边就永远不可能到达左边,同理如果钥匙在右边,左边就永远不可能到达右边. 然后考虑一个暴力的 ...

  9. LOJ2303 「NOI2017」蚯蚓排队

    「NOI2017」蚯蚓排队 题目描述 蚯蚓幼儿园有$n$只蚯蚓.幼儿园园长神刀手为了管理方便,时常让这些蚯蚓们列队表演. 所有蚯蚓用从$1$到$n$的连续正整数编号.每只蚯蚓的长度可以用一个正整数表示 ...

随机推荐

  1. GitLab基本设置-新增用户

    场景 Docker Compose部署GitLab服务,搭建自己的代码托管平台(图文教程): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/det ...

  2. git配置:本地仓库提交到远程仓库

    前提:1.已安装git 一:创建公钥,一台机子匹配一个公钥 桌面右键选择 Git Bash Here 打开命令行输入:ssh-keygen -t rsa -C "xxx@xxx.com&qu ...

  3. Dynamics 365-当OrganizationServiceProxy是Null的时候

    不少从事D365研发工作的朋友,可能或多或少都经历过这么一种情况,使用CrmServiceClient对象初始化一个实例,然后发现OrganizationServiceProxy对象是null.不仅如 ...

  4. Abusing SUDO Advance for Linux Privilege Escalation

    Index What is SUDO? Scenario. Sudoer FIle Syntax. Exploiting SUDO zip tar strace tcpdump nmap scp ex ...

  5. MTK Recovery 模式横屏修改(适用于6.0 + 8.1)

    修改前 修改后 6.0 Recovery 模式横屏修改方法 修改相关文件 bootable\recovery\minui\Android.mk bootable\recovery\minui\mt_g ...

  6. Windows 10 神州网信版

    一.版本介绍:官网链接:http://document.cmgos.com/release_notes/release_notes_V0_H 下载链接:请自行百度Windows 10 神州网信政府版( ...

  7. 初级模拟电路:3-11 BJT实现电流源

    回到目录 1. 恒流源 (1)简易恒流源 用BJT晶体管可以构造一个简易的恒流源,实现电路如下: 图3-11.01 前面我们在射极放大电路的分压偏置时讲过,分压偏置具有非常好的稳定性,几乎不受晶体管的 ...

  8. 生成对抗性网络GAN

    同VAE模型类似,GAN模型也包含了一对子模型.GAN的名字中包含一个对抗的概念,为了体现对抗这个概念,除了生成模型,其中还有另外一个模型帮助生成模型更好地学习观测数据的条件分布.这个模型可以称作判别 ...

  9. springboot之jpa的支持

    1.springboot之jpa支持 2.Springboot+bootstrap界面版之增删改查及图片上传 springboot之jpa支持 导入相关pom依赖 <dependency> ...

  10. day100_12_4DataFrame和matplotlib模块

    一.Dataframe的分组. 再网页表格数据 的分析中,可以使用以下语句进行爬取表格. res = pd.read_html('https://baike.baidu.com/item/NBA%E6 ...