博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2-SAT速成
阅读量:6969 次
发布时间:2019-06-27

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

本文只做总结性说明

2-SAT

2-SAT是k-SAT问题的一种,k-SAT问题在\(k>=3\)时已经被证明是NP完全问题

2-SAT问题定义比较简单

有n个布尔变量\(x_1-x_n\)。给出\(m\)个限制关系,每个关系最多只对两个变量进行限制。求一组取值使得满足所有限制。

这里的限制例如:选\(A\)必选\(B\) 或是 \(A,B\)至少选一个

解决方法

2-SAT问题所构成的图具有对称性

对于两个点来说

即若选\(A\)必选\(B\),那么选\(B\)必选\(A\)

根据这种性质,前人总结出了一种方法

将一个点\(A\)拆为\(A,A'\)

1.若选\(A\)必选\(B\),那么从\(A\)\(B\)连一条边

2.tarjan缩点(把时间从\(O(NM)\)优化至\(O(n)\))

3.判断是否\(A'A\)是否在同一强联通分量中

对于需要输出方案的题目

4.根据缩完点的图,建出其反图

5.对反图进行拓扑排序

6.根据拓扑排序的顺序标记答案

经典模型

  • 两者(A,B)不能同时取

那么选择了A就只能选择B’,选择了B就只能选择A’

连边A→B’,B→A’

  • 两者(A,B)不能同时不取

那么选择了A’就只能选择B,选择了B’就只能选择A

连边A’→B,B’→A

  • 两者(A,B)要么都取,要么都不取

那么选择了A,就只能选择B,选择了B就只能选择A,选择了A’就只能选择B’,选择了B’就只能选择A’

连边A→B,B→A,A’→B’,B’→A’

  • 两者(A,A’)必取A

  连边A’→A

\(A'A\)不能同时出现,选\(A'\)必选\(A\),故只能单独选\(A\)

例题

由简单到简单2333

转载地址:http://miasl.baihongyu.com/

你可能感兴趣的文章
【转】从bundle中复制文件到Documents目录中的代码
查看>>
【转】UIWebView获取当前页面url的两种方法
查看>>
struts2中使用ajax so easy!!!
查看>>
Hibernate 事物隔离级别
查看>>
Linux ——记一记那恐怖的 rm -f
查看>>
C# 指针之美
查看>>
Oracle 10 参数配置说明
查看>>
解决'System.OutOfMemoryException' 的问题
查看>>
消息队列RabbitMQ和ActiveMQ的生产者流量控制
查看>>
再论 重载、覆盖、多态与函数隐藏
查看>>
Android 用户界面---菜单
查看>>
【学术报告】云山物罩 大话‘大数据’
查看>>
用Setup系列函数完成驱动卸载安装[驱动安装卸载程序]
查看>>
巧妙利用JQuery和Servlet来实现跨域请求
查看>>
JS中生成与解析JSON
查看>>
[开发记录]事件驱动中一种优雅的退出方法
查看>>
java对象转JSON JS取JSON数据
查看>>
Spring MVC 学习 之 - 拦截器
查看>>
Leetcode: Minimum Window Substring
查看>>
jQuery 时间控件推荐
查看>>