博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2-sat专题
阅读量:5086 次
发布时间:2019-06-13

本文共 708 字,大约阅读时间需要 2 分钟。

复习2-sat小结

2-sat 就是用来解决像和平委员会这样的问题

即有很多只有两个取值的变量,且有一些形如"A取1,B就取/不取1"的限制条件

问是否存在合法方案

首先基本的建图就是先拆点,每个点拆成(0,1)

对于限制条件A取1,B就取0,那么就从A1向B0连边

最终如果A1和A0在同一个强连通分量就无解

因为A既是1又是0,显然不合法

对于输出方案

我们可以先拓扑排序

拓扑序大的先取出,因为它没有出边了,选它不会有影响,然后删除它的另一个取值所对应的点

然后可以用一个简单算法堆起来的算法得出方案

但是我们也可以对每个变量,取tarjan时所属连通块编号小的

为什么呢?

tarjan取连通块是从下到上的,那编号小的就是拓扑序大的

如果要求字典序最小解,那就只能暴力找了

从小到大枚举每个变量的取值,然后dfs一遍看是否有变量既要取1又要取0

没有就合法

2-sat第一题肯定是和平委员会

裸的2-sat,只是要输方案

bzoj1997&&poj3207

传送门:

平面图判定

每条边不在外面就在里面,如果有交,就不能放在一侧,然后就是典型的2-sat了

poj2749

传送门:

二分距离,2-sat判定

poj3678

传送门:

一道好题

xor好办

关键是a and b=1 就由a0向a1连边,b0->b1,a1->b1,b1->a1

a or b=0类似

bzoj2199

传送门:

求最小字典序解,只能暴力

bzoj2215

传送门:

写完这题就可以洗洗睡了,确实是一道坑爹愉悦的题

题解:

转载于:https://www.cnblogs.com/thythy/p/5493470.html

你可能感兴趣的文章
聚合与组合
查看>>
jQuery如何获得select选中的值?input单选radio选中的值
查看>>
设计模式 之 享元模式
查看>>
如何理解汉诺塔
查看>>
洛谷 P2089 烤鸡【DFS递归/10重枚举】
查看>>
15 FFT及其框图实现
查看>>
Linux基本操作
查看>>
osg ifc ifccolumn
查看>>
C++ STL partial_sort
查看>>
3.0.35 platform 设备资源和数据
查看>>
centos redis 安装过程,解决办法
查看>>
IOS小技巧整理
查看>>
WebDriverExtensionsByC#
查看>>
我眼中的技术地图
查看>>
lc 145. Binary Tree Postorder Traversal
查看>>
sublime 配置java运行环境
查看>>
在centos上开关tomcat
查看>>
重启rabbitmq服务
查看>>
正则表达式(进阶篇)
查看>>
无人值守安装linux系统
查看>>