【学习笔记】 2-SAT问题
Algorithm Description
\(2-SAT\)问题就是给定一串布尔变量,每个变量只能为真或假。
要求对这些变量进行赋值,满足布尔方程。
会有一些形如 \(x_1||x_2\) 或者 \(x_5||(!x_6)\) 的条件
所谓布尔方程就是赋值之后满足所有的条件
首先扯一句,如果这个条件变成三或者三以上个\(x\)相关的了,就只能\(2^n\)枚举了
(好像是 \(N-SAT\) 问题是 \(NP\) 完全的)
然后我们思考如何求解这样的问题
前人告诉我们,可以把这些变量转移到图上进行操作
\]
首先拆点: \(i->i\) 同时 \((!i)->i+n\)
然后我们我们考虑建图的时候
对于每一个条件: \(a||b\) ,连上 \((!a)->b\) 和 \((!b)->a\) 的两条有向边
这里可以理解成【\(b\) 假则 \(a\) 必须真,\(a\) 假则 \(b\)必须真】
考虑 \(tarjan\) 求一波强连通分量,如果有 \(scc[i]==scc[i+n]\) 直接无解
显然真假是不一样的(就是不能赋相同的值)
\]
如果要跑方案,就直接输出\([scc[i]<scc[i+n]]\) 就好
例题
由于实在是模板题(不知为啥当时放这么一个纯板子……),就不写了
Code:
#include<bits/stdc++.h>
using namespace std;
#define int long long
namespace yspm{
inline int read()
{
int res=0,f=1; char k;
while(!isdigit(k=getchar())) if(k=='-') f=-1;
while(isdigit(k)) res=res*10+k-'0',k=getchar();
return res*f;
}
const int N=4e6+10;
int n,m,a,b,x,y,tim,top,tot,cnt;
int dfn[N],low[N],st[N],vis[N],scc[N],head[N];
struct node{int to,nxt;}e[N];
inline void add(int u,int v){e[++cnt].nxt=head[u],e[cnt].to=v; head[u]=cnt; return ;}
inline void tarjan(int u,int fa)
{
dfn[u]=low[u]=++tim; st[++top]=u; vis[u]=1;
for(int i=head[u];i;i=e[i].nxt)
{
int t=e[i].to; if(t==fa) continue;
if(!dfn[t]) tarjan(t,u),low[u]=min(low[u],low[t]);
else if(vis[t]) low[u]=min(low[u],dfn[t]);
}
if(dfn[u]==low[u])
{
tot++; while(st[top]!=u) scc[st[top]]=tot,vis[st[top--]]=0;
scc[st[top]]=tot; vis[st[top--]]=0;
}
return ;
}
signed main()
{
n=read(); m=read();
for(int i=1;i<=m;++i)
{
a=read(); x=read(); b=read(); y=read();
if(!x&&!y) add(a+n,b),add(b+n,a);
if(!x&&y) add(a+n,b+n),add(b,a);
if(x&&!y) add(a,b),add(b+n,a+n);
if(x&&y) add(a,b+n),add(b,a+n);
}
for(int i=1;i<=2*n;++i) if(!dfn[i]) tarjan(i,0);
for(int i=1;i<=n;++i)
{
if(scc[i]==scc[i+n]) return puts("IMPOSSIBLE"),0;
}
puts("POSSIBLE"); for(int i=1;i<=n;++i) printf(scc[i]>scc[i+n]?"1 ":"0 ");
return 0;
}
}
signed main(){return yspm::main();}
瞎看吧,这个 \(add\) 压行有点严重了,没去格式化 \(2333\)
【学习笔记】 2-SAT问题的更多相关文章
- <老友记>学习笔记
这是六个人的故事,从不服输而又有强烈控制欲的monica,未经世事的千金大小姐rachel,正直又专情的ross,幽默风趣的chandle,古怪迷人的phoebe,花心天真的joey——六个好友之间的 ...
- OGG学习笔记02-单向复制配置实例
OGG学习笔记02-单向复制配置实例 实验环境: 源端:192.168.1.30,Oracle 10.2.0.5 单实例 目标端:192.168.1.31,Oracle 10.2.0.5 单实例 1. ...
- python数据分析入门学习笔记
学习利用python进行数据分析的笔记&下星期二内部交流会要讲的内容,一并分享给大家.博主粗心大意,有什么不对的地方欢迎指正~还有许多尚待完善的地方,待我一边学习一边完善~ 前言:各种和数据分 ...
- 【MarkMark学习笔记学习笔记】javascript/js 学习笔记
1.0, 概述.JavaScript是ECMAScript的实现之一 2.0,在HTML中使用JavaScript. 2.1 3.0,基本概念 3.1,ECMAScript中的一切(变量,函数名,操作 ...
- Linux 学习笔记之超详细基础linux命令 Part 13
Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 12---------------- ...
- Linux 学习笔记之超详细基础linux命令 Part 8
Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 7----------------- ...
- Deep learning with Python 学习笔记(5)
本节讲深度学习用于文本和序列 用于处理序列的两种基本的深度学习算法分别是循环神经网络(recurrent neural network)和一维卷积神经网络(1D convnet) 与其他所有神经网络一 ...
- 【Redis】命令学习笔记——字符串(String)(23个超全字典版)
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合). 本篇基于redis 4.0.11版本,学习字符串( ...
- programming-languages学习笔记--第3部分
programming-languages学习笔记–第3部分 */--> pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src ...
- 学习笔记 - 2sat
学习笔记 - 2sat 决定重新启用Markdown--只是因为它支持MathJax数学公式 noip考完,既轻松又无奈,回来慢慢填坑 这篇博客也是拖了好久,通过kuangbin的博客才弄懂2-sat ...
随机推荐
- WebFlux系列(十二)MongoDB应用,新增、修改、查询、删除
#Java#Spring#SpringBoot#Mongo#reactor#webflux#数据库#新增#修改#查询#删除# Spring Boot WebFlux Mongo数据库新增.删除.查询. ...
- 吴裕雄--天生自然Django框架开发笔记:Django Admin 管理工具
Django 提供了基于 web 的管理工具. Django 自动管理工具是 django.contrib 的一部分.可以在项目的 settings.py 中的 INSTALLED_APPS 看到它: ...
- Android进阶——多线程系列之Semaphore、CyclicBarrier、CountDownLatch
今天向大家介绍的是多线程开发中的一些辅助类,他们的作用无非就是帮助我们让多个线程按照我们想要的执行顺序来执行.如果我们按照文字来理解Semaphore.CyclicBarrier.CountDownL ...
- VUE v-if与v-show
v-if 本质:vue-if是动态的向DOM树内添加或者删除DOM元素 优点:更加灵活 <li v-for="(item, index) in scene" v-if=&qu ...
- openstack trove weekly meeting时间即将更改
为了平衡英国.巴黎.德国.美国和中国开发者的作息习惯,openstack trove项目组在5月18日的weekly meeting上开始讨论新的开会时间. 当前的开会时间是,周三 UTC 18:00 ...
- 18 11 26 用多进程 多线程 携程 实现 http 服务器的创建
下面是一个 多进程 服务器的创建 import socket import re import multiprocessing def service_client(new_socket): &qu ...
- linux 下shell 编写脚本
linux 下shell 编写脚本: 1.程序结构练习:编写一个脚本,给定一个正整数,计算出这个数所有位的数字之和. 例如:程序给定输入123,那么应该返回1+2+3=6. 2.程序结构练习:编写一个 ...
- JDK8 API离线文档免费下载&JavaEE API文档离线下载&API在线查看链接&常用的JAR包下载
1.JDK8 API离线文档 链接:https://pan.baidu.com/s/1fYc-QesmYRumTEPmnSgEKA 提取码:2bdr 2.JavaEE API文档离线下载 链接:htt ...
- eclipse默认的WebContent目录修改为webRoot
从网上下载了个Java Web项目,导入Eclipse后在Tomcat中发布,发现在Tomcat的Webapps目录下没有JSP页面 到项目中去看才发现有两个目录,一个WebContent,一个Web ...
- dp--树形dp P1352 没有上司的舞会
题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数Ri, ...