2-SAT超入门讲解
Preface
说实话2-SAT的题目我都没怎么做过,所以这里讲的都是些超入门什么的
还有一些板子题,由于是暑假的时候学的所以有些我也记不清了
主要学习参考自:Mancher的课件&&dalao's blog&&Another dalao
What is 2_SAT?
SAT是适定性(Satisfiability)问题的简称 。一般形式为k-适定性问题,简称 k-SAT。
可以证明,当\(k>2\)时,k-SAT是NP完全的。因此一般讨论的是\(k=2\)的情况,即2-SAT问题。
我们通俗的说,就是给你\(n\)个变量\(a_i\),每个变量能且只能取\(0/1\)的值。同时给出若干条件,形式诸如\((not)a_i\operatorname{opt}(not)\ a_j=0/1\),其中\(opt\)表示\(and,or,xor\)中的一种
而求解2-SAT的解就是求出满足所有限制的一组\(a\)
Change 2-SAT into Graph Theory
首先我们考虑将2-SAT问题往图论的方向靠,我们发现每个点要么取\(0\),要么取\(1\)。因此对于\(a_i\),我们建两个点\(2i-1\)与\(2i\)分别表示\(a_i\)取\(0\)和\(1\)
然后我们考虑建边来表示这些关系,我们令一条有向边的意义:\(x\to y\)表示如果选择了\(x\)就必须选\(y\)
那么我们可以举一些简单的例子来总结下连边的规律(用\(i'\)表示\(i\)的反面):
- \(i,j\)不能同时选:选了\(i\)就要选\(j'\),选\(j\)就要选\(i'\)。故\(i\to j',j\to i'\)。一般操作即为\(a_i \operatorname{xor} a_j=1\)
- \(i,j\)必须同时选:选了\(i\)就要选\(j\),选\(j\)就要选\(i\)。故\(i\to j,j\to i\)。一般操作即为\(a_i \operatorname{xor} a_j=0\)
- \(i,j\)只且只且选一个:选了\(i\)就要选\(j'\),选\(j\)就要选\(i'\),选\(i'\)就要选\(j\),选\(j'\)就要选\(i\)。故\(i\to j',j\to i',i'\to j,j'\to i\)。一般操作即为\(a_i \operatorname{or} a_j=1\)
- \(i\)必须选:直接\(i'\to i\),可以保证无论怎样都选\(i\)。一般操作为给出的\(a_i=1\)或\(a_i \operatorname{and} a_j=1\)
建好图然后就是考虑怎么用图论的方式解决2-SAT了。
How to solve 2-SAT——DFS
- 对于每个当前不确定的变量\(a_i\),令\(a_i=0\)然后沿着边DFS访问相连的点。
- 检查如果会导致任意一个\(j\)与\(j'\)都被选,那么撤销。否则令\(a_i=0\)
- 否则令\(a_i=1\),重复2。如果还不行就无解。
- 继续考虑下一个不确定的变量
这样的话正确性显然,由于这里的DFS涉及到全局,因此复杂度是\(O(n(n+m))\)的。
一般情况下已经很优秀了,而且还可以改进:
只需要在DFS之前判断\(i'\)能否走到\(i\)就可以省略撤销标记的过程,所以我们可以bitset优化传递闭包做到\(O(\frac{n+m}{w})\)预处理,然后就可以\(O(n+m)\)的DFS了。
这种做法还可以保证解的字典序,有时不失为一种不错的方法。
How to solve 2-SAT——SCC
考虑我们上面的判断有无解的情况,我们想到完全可以借助SCC来判断两个点是否互相到达。
那么我们先缩点,如果\(i\)与\(i'\)在同一SCC里那么显然无解。
否则选择\(i\)与\(i'\)中拓扑序较大的一个就可以得到一组可行解。
不是很常用(主要是一般题目的数据范围都不需要),用来判可行性比较好。
两道例题
- HDU 3062Party 2-SAT建图后判断可行性即可。
- HDU 1814Peaceful Commission 2-SAT建图后求字典序最小解,就用DFS的方法不预处理也可以过。
Postscript
这真的是一篇超入门博客,没有涉及特别多的难点以及姿势。
像数据结构优化建图我是肯定不会的啦,最后推荐一道比较有难度的2-SAT好题:Luogu P3825 [NOI2017]游戏&&Sol
2-SAT超入门讲解的更多相关文章
- Mysql C语言API编程入门讲解
原文:Mysql C语言API编程入门讲解 软件开发中我们经常要访问数据库,存取数据,之前已经有网友提出让鸡啄米讲讲数据库编程的知识,本文就详细讲解如何使用Mysql的C语言API进行数据库编程. ...
- 超细讲解Django打造大型企业官网
本文为知了课堂黄勇老师讲的<超细讲解Django打造大型企业官网>的笔记. 第一章 Django预热 1.创建virtualenv虚拟环境 2.URL组成部分详解 3.Django介绍 4 ...
- #001 CSS快速入门讲解
CSS入门讲解 HTML人+CSS衣服+JS动作=>DHTML CSS: 层叠样式表 CSS2.0 和 CSS3.0 版本,目前学习CSS2, CSS3只是多了一些样式出来而已 CSS 干啥用的 ...
- HTML5游戏开发引擎Pixi.js新手入门讲解
在线演示 本地下载 这篇文章中,介绍HTML5游戏引擎pixi.js的基本使用. 相关代码如下: Javascript 导入类库:(使用极客的cdn服务:http://cdn.gbtags.com) ...
- AngularJS入门讲解4:多视图,事件绑定,$resource服务讲解
上一课,大家知道,手机详细模板我们没有写出来,使用的是一个占位模板. 这一课,我们先实现手机详细信息视图,这个视图会在用户点击手机列表中的一部手机时被显示出来. 为了实现手机详细信息视图,我们将会使用 ...
- poj2104 k-th number 主席树入门讲解
poj2104 k-th number 主席树入门讲解 定义:主席树是一种可持久化的线段树 又叫函数式线段树 刚开始学是不是觉得很蒙逼啊 其实我也是 主席树说简单了 就是 保留你每一步操作完成之后 ...
- #001 HTML快速入门讲解
整理了下最早开始学习技术的笔记 3W1H学习法? (其他技术同理) What HTML是什么? When 什么时候使用HTML? Why 为什么使用HTMl? HOW 怎么使用HTML ...
- 原生AJAX入门讲解(含实例)
相对于jQuery.YUI以及其他一些类库的AJAX封装,原生JS的AJAX显得那么的尴尬,兼容性不好,要记很多的方法属性,调用不便捷,代码臃肿...但我还是想说,原生JS才是最根本最底层的知识(虽然 ...
- win8.1上wamp环境中利用apache自带ab压力测试工具使用超简单讲解
2015.10.4apache自带ab压力测试工具使用:本地环境:win8.1 wampserver2.5 -Apache-2.4.9-Mysql-5.6.17-php5.5.12-64b 可以参考一 ...
随机推荐
- SoapUI 利用SoapUI进行简单的接口并发测试
利用SoapUI进行简单的接口并发测试 by:授客 QQ:1033553122 测试环境: SoapUI Pro 5.1.2 步骤如下 1. 把请求添加到测试套件 1.1. 途径1 1.新 ...
- Anaconda3 错误集合
1. An error ocurred while starting the kernel 答:个人猜测有可能是配置文件出现问题,于是采用如下解决方法: 在终端中输入spyder --reset,重置 ...
- 03-12_MBean层次结构
本文重点: Mbeans层次结构与WLST关系介绍 WebLogic Mbeans的类型 weblogic服务器的MBeans生命周期 Mbeans层次结构与WLST关系介绍: ...
- VB6 对象库未注册问题
以下是个人使用VB6出现对象库未注册问题的解决方法.已成功! 一.注册ocx文件 mscomctl.ocx文件放进路径C:\Windows\System32(64是此路径,由于本人是64位系统32位未 ...
- 配置私有SSH
1.cd ~/.ssh进入ssh文件夹. 2.ls,查看文件夹里面的内容 3.ssh-keygen -t rsa -C "zhanggui@marchsoft.cn” 一路回车 4.cd ~ ...
- 学生&部门智能匹配程序
Github链接 结对成员: 031502308 付逸豪 031502113 胡俊钦 数据生成 样例链接: 来点我啊 由于在生成数据的时候做了很多符合实际情况的限制,所以生成的数据都挺好的,就随便选了 ...
- SAP S4/HANA BP屏幕增强添加自定义字段(BDT方式)
喜欢博主的读者也许会意识到,这是本博客中第一篇有关屏幕增强的文章.之前没有总结过相关的东西,除了因为相关经验有限之外,我个人也是不喜欢所谓dynpro编程的,它有许多“潜规则”一样的东西要记住,想要运 ...
- 在Eclipse中使用Maven jetty的debug模式
1.右键项目debug as添加mvn命令: jetty:run 2.进入eclipse的菜单Run->Debug configurations,会看到maven build下对应的项目的mvn ...
- 离线安装PostgreSQL
postgresql在线安装很简单,但是很多情况,服务器不能联网,需要离线安装.下面是离线安装的步骤: 1. 首先进入官网: https://www.postgresql.org/ 2. 点击Down ...
- Ubuntu18.04安装Tensorflow+cuda+cuDNN
本文写的比较简单,期间遇到的一些小麻烦,自己不认为成为阻碍,所以没有详细写. 如有疑问可以联系QQ:2922530320 Pycharm Pycharm使用Anaconda Pycharm 在新建项目 ...