LG3825/BZOJ4945/LOJ2305 「NOI2017」游戏 dfs+2-SAT
问题描述
题解
发现对于每个地图,如果没有\(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的更多相关文章
- LOJ2305 「NOI2017」游戏
「NOI2017」游戏 题目背景 狂野飙车是小 L 最喜欢的游戏.与其他业余玩家不同的是,小 L 在玩游戏之余,还精于研究游戏的设计,因此他有着与众不同的游戏策略. 题目描述 小 L 计划进行$n$场 ...
- 「NOI2017」游戏
「NOI2017」游戏 题目描述 小 L 计划进行 \(n\) 场游戏,每场游戏使用一张地图,小 L 会选择一辆车在该地图上完成游戏. 小 L 的赛车有三辆,分别用大写字母 \(A\).\(B\).\ ...
- loj #2305. 「NOI2017」游戏
#2305. 「NOI2017」游戏 题目描述 小 L 计划进行 nnn 场游戏,每场游戏使用一张地图,小 L 会选择一辆车在该地图上完成游戏. 小 L 的赛车有三辆,分别用大写字母 AAA.BBB. ...
- LOJ_2305_「NOI2017」游戏 _2-sat
LOJ_2305_「NOI2017」游戏 _2-sat 题意: 给你一个长度为n的字符串S,其中第i个字符为a表示第i个地图只能用B,C两种赛车,为b表示第i个地图只能用A,C两种赛车,为c表示第i个 ...
- 「NOI2017」游戏 解题报告
「NOI2017」游戏 \(d\)这么小,你考虑直接对\(d\)个东西暴力 枚举\(x\)为\(a\)或\(b\)(\(c\)就不用了,因为\(a,b\)已经包含\(c\))了,剩下的就是个\(2-s ...
- 【LOJ】 #2305. 「NOI2017」游戏
题解 枚举x所在的地图的颜色,然后2-SAT建边 如果v所在的地图刚好是不能选的,那么u这边只能选另一种颜色 否则就是u的颜色到v的颜色 v的另一种颜色到u的另一种颜色 代码 #include < ...
- loj#2305. 「NOI2017」游戏 2-sat
链接 https://loj.ac/problem/2305 https://www.luogu.org/problemnew/show/P3825 思路 3-sat神马的就不要想了,NP问题 除去x ...
- 「HNOI2018」游戏
「HNOI2018」游戏 解题思路 首先没有锁上的门可以缩点缩掉,然后对于一扇锁上的门,如果钥匙在左边,那么右边就永远不可能到达左边,同理如果钥匙在右边,左边就永远不可能到达右边. 然后考虑一个暴力的 ...
- LOJ2303 「NOI2017」蚯蚓排队
「NOI2017」蚯蚓排队 题目描述 蚯蚓幼儿园有$n$只蚯蚓.幼儿园园长神刀手为了管理方便,时常让这些蚯蚓们列队表演. 所有蚯蚓用从$1$到$n$的连续正整数编号.每只蚯蚓的长度可以用一个正整数表示 ...
随机推荐
- postgreSQL安装教程 Windows
Windows 上安装 PostgreSQL 这里使用 EnterpriseDB 来下载安装,EnterpriseDB 是全球唯一一家提供基于 PostgreSQL 企业级产品与服务的厂商. 下载地址 ...
- 推荐一款好看的Hexo主题Ayer
介绍 Ayer 是一个干净且优雅的Hexo主题,自带响应式,加载速度很快,该有的功能都有,可配置项也很多,非常适合作为你的博客主题,主题内还附送了6张精美的高清壁纸.欢迎使用和Star支持,如果你在使 ...
- [转]UIpath advanced certification dumps
本文转自:https://dotnetbasic.com/2019/06/uipath-advanced-certification-dumps.html UiPath advanced certif ...
- canvas在vue中的应用
使用cavas可以绘制各种图表.生成二维码.制作H5小游戏. 生命周期 canvas应该在mounted的生命周期中初始化,在updated中是无效的. export default { mounte ...
- Test111
这是一个测试 以下是截图 以下是代码标记 @@@code [XmlRpcMethod("blogger.deletePost")] haaa ggg @@# publi ...
- Httpclient 4.5.2 请求重试机制
重点是HttpRequestRetryHandler.retryRequest()方法 public static String callHttpServer(String contentType,S ...
- Python学习笔记六(免费获取代理IP)
为获取网上免费代理IP,闲的无聊,整合了一下,免费从三个代理网站获取免费代理IP,目的是在某一代理网站被限制时,仍可从可以访问的其他网站上获取代理IP.亲测可用哦!^_^ 仅供大家参考,以下脚本可添 ...
- DynamicList
DynamicList设计要点——类模板 申请连续空间作为顺序存储空间 动态设置顺序存储空间的大小 保证重置顺序存储空间时的异常安全性 DynamicList设计要点——函数异常安全的概念 不泄露任何 ...
- 关于input标签不同type下的盒模型
刚才发现,在Chrome下input标签的不同type类型所取的盒模型是不一样的.浪费了我很多时间去调试,唉. type="text"时,给它设置宽度width:300px,此时的 ...
- ES6 ES7 ES8 相关用法
set Set作为ES6新的数据解构(类数组),它的成员都是唯一的,因为最直接的使用场景便是去重.并.差.交集的使用.它使用的算法叫做“Same-value-zero equality”,类似精确运算 ...