2-SAT
SAT 是适定性(Satisfiability)问题的简称。一般形式为 k - 适定性问题,简称 k-SAT。而当
时该问题为 NP 完全的。所以我们只研究 的情况。
定义
2-SAT,简单的说就是给出
现实意义
比如邀请人来吃喜酒,夫妻二人必须去一个,然而某些人之间有矛盾(比如 A 先生与 B 女士有矛盾,C 女士不想和 D 先生在一起),那么我们要确定能否避免来人之间有矛盾,有时需要方案。这是一类生活中常见的问题。
使用布尔方程表示上述问题。设
常用解决方法
Tarjan SCC 缩点
算法考究在建图这点,我们举个例子来讲:
假设有
然后通过这样子建边我们跑一遍 Tarjan SCC 判断是否有一个集合中的两个元素在同一个 SCC 中,若有则输出不可能,否则输出方案。构造方案只需要把几个不矛盾的 SCC 拼起来就好了。
输出方案时可以通过变量在图中的拓扑序确定该变量的取值。如果变量
显然地,时间复杂度为
暴搜
就是沿着图上一条路径,如果一个点被选择了,那么这条路径以后的点都将被选择,那么,出现不可行的情况就是,存在一个集合中两者都被选择了。
那么,我们只需要枚举一下就可以了,数据不大,答案总是可以出来的。
例题
HDU3062 Party
题面:有 n 对夫妻被邀请参加一个聚会,因为场地的问题,每对夫妻中只有
人可以列席。在 个人中,某些人之间有着很大的矛盾(当然夫妻之间是没有矛盾的),有矛盾的 个人是不会同时出现在聚会上的。有没有可能会有 个人同时列席?
这是一道多校题,裸的 2-SAT 判断是否有方案,按照我们上面的分析,如果
2018-2019 ACM-ICPC Asia Seoul Regional K TV Show Game
题面:有
盏灯,每盏灯是红色或者蓝色,但是初始的时候不知道灯的颜色。有 个人,每个人选择 3 盏灯并猜灯的颜色。一个人猜对两盏灯或以上的颜色就可以获得奖品。判断是否存在一个灯的着色方案使得每个人都能领奖,若有则输出一种灯的着色方案。
这道题在判断是否有方案的基础上,在有方案时还要输出一个可行解。
根据 伍昱 -《由对称性解 2-sat 问题》,我们可以得出:如果要输出 2-SAT 问题的一个可行解,只需要在 tarjan 缩点后所得的 DAG 上自底向上地进行选择和删除。
具体实现的时候,可以通过构造 DAG 的反图后在反图上进行拓扑排序实现;也可以根据 tarjan 缩点后,所属连通块编号越小,节点越靠近叶子节点这一性质,优先对所属连通块编号小的节点进行选择。
下面给出第二种实现方法的代码。
练习题
POJ3683 牧师忙碌日
贡献者:@felixesintot@akakw1@Ir1d@H-J-Granger@kenlig@jpy-cpp@mgt@lazycccat@guodong@Zhikai@Nano@Early@ouuan@sshwy@Anguei@frank@AndrewWayne
本页面最近更新:2/3/2023, 12:00:00 AM,更新历史
发现错误?想一起完善? 在 GitHub 上编辑此页!
本页面的全部内容在 CC BY-SA 4.0 和 SATA 协议之条款下提供,附加条款亦可能应用