2-SAT问题的方案输出
2-sat 推荐学习资料:
伍昱的2003年IOI国家集训队论文《由对称性解2-sat问题》
论文链接:https://wenku.baidu.com/view/31fd7200bed5b9f3f90f1ce2.html
注:
本博文只分析如何输出一组可行解,请读者确保已学习了判断是否有解
本人水平不高,若有分析不得当之处,欢迎指出
法一、tarjan+构建反图+拓扑排序
在原图tarjan缩点后得到的有向无环图的反图上拓扑排序
边拓扑边干两件事儿:
1、选择当前栈顶所代表的问题
2、删除与栈顶问题相对立的问题,删除它在反图上的后继问题
个人理解:
1、一般情况下,2-SAT的构图是对称的,(原因去看论文)
设i与i'为一对相互对立的问题
若在原图中存在下面的左边的连通子图则必存在右边的连通子图
非一般情况比如NOI2017 Day2 T1 游戏,
输入数据会使存在边i-->i',但不一定存在边i'-->i
即给出的约束条件使原本就设定的对立问题 再连边
2、在原图中一条边u-->v代表着如果选择问题u则必须选择问题v
而选择了问题v不一定要选择问题u
在实现的时候,如果在反图上进行拓扑排序,
反图中入度为0的点,对应着原图中出度为0的点,它在原图中没有后继问题
相当于省去了在原图中拓扑排序的还要选择它所有的后继问题
3、在原图中一条边u-->v代表着 如果不选v,则一定不选u
栈顶问题的对立问题一定不能选,所以原图中还要删除对立问题的所有前驱问题
对应到反图中就是后继问题
在具体实现的时候,我们可以使这些栈顶对立问题的后继问题永远不能入栈
不删除栈顶对立问题的出边即可
法二:tarjan
tarjan缩点时会给点重新编号
对于一对相互对立的问题,谁的新编号小就选谁
此方法对于非对称图也适用
反图上在拓扑排序中选择,等价于
原图(缩点后的树)上 从叶子节点开始,自底部向上选择的过程
而tarjan缩点重标号也是从叶子节点往上
2-SAT问题的方案输出的更多相关文章
- Ring HDU - 2296 AC自动机+简单DP和恶心的方案输出
题意: 就是现在给出m个串,每个串都有一个权值,现在你要找到一个长度不超过n的字符串, 其中之前的m个串每出现一次就算一次那个字符串的权值, 求能找到的最大权值的字符串,如果存在多个解,输出最短的字典 ...
- CF-1354 E. Graph Coloring(二分图,背包,背包方案输出)
E. Graph Coloring 链接 n个点m条边的无向图,不保证联通,给每个点标号1,2,3.1号点个数n1,2号点个数n2,3号点个数n3.且每条边的两点,标号之差绝对值为1.如果有合法方案, ...
- poj 2125 Destroying The Graph 最小割+方案输出
构图思路: 1.将所有顶点v拆成两个点, v1,v2 2.源点S与v1连边,容量为 W- 3.v2与汇点连边,容量为 W+ 4.对图中原边( a, b ), 连边 (a1,b2),容量为正无穷大 则该 ...
- luogu P2066 机器分配[背包dp+方案输出]
题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...
- POJ 3683 Priest John's Busiest Day(2-SAT+方案输出)
Priest John's Busiest Day Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 10010 Accep ...
- poj 1015 Jury Compromise(背包+方案输出)
\(Jury Compromise\) \(solution:\) 这道题很有意思,它的状态设得很...奇怪.但是它的数据范围实在是太暴露了.虽然当时还是想了好久好久,出题人设了几个限制(首先要两个的 ...
- Vijos 1071 && caioj 1411 动态规划2:打牌 (背包方案输出)
非常奇怪的是,我在Vijos 1071能AC,在caioj 就只有50分 可以和前面一道题一样算方案,如果大于1就是多解 然后就输出方案就好了 #include<cstdio> #incl ...
- 单片机一种简便的printf调试方案。
此处引用csdn博客.链接如下. http://blog.csdn.net/cp1300/article/details/7773239 http://blog.csdn.net/aobai219/a ...
- 【洛谷】NOIP提高组模拟赛Day1【组合数学】【贪心+背包】【网络流判断是否满流以及流量方案】
U41568 Agent1 题目背景 2018年11月17日,中国香港将会迎来一场XM大战,是世界各地的ENLIGHTENED与RESISTANCE开战的地点,某地 的ENLIGHTENED总部也想派 ...
随机推荐
- C#字符串截取、获取当前电脑时间、判断输入日期对错 随手记
字符串截取:这个就当复习了,看意见就可以 //身份证生日截取 //Console.WriteLine("请输入18位身份证号:"); //string x = Console.Re ...
- Edit Distance问题在两种编程范式下的求解
本文已授权 [Coding博客](https://blog.coding.net) 转载 前言 Edit Distance,中文叫做编辑距离,在文本处理等领域是一个重要的问题,以下是摘自于百度百科的定 ...
- docker-compose编排
创建并启动容器 docker-compose up -d 备注: -d 后台启动并运行容器 前提是你在执行该命令的时候已经编写好了docker-compose.yml文件,在这个文件的当前目录执行上述 ...
- Async 异步转同步详细流程解释
安装 npm install async --save 地址 https://github.com/caolan/async Async的内容主要分为三部分 流程控制: 简化九种常见的流程的处理 ...
- PAT甲题题解-1031. Hello World for U (20)-字符串处理,水
#include <iostream> #include <cstdio> #include <algorithm> #include <string.h&g ...
- 第二阶段冲刺——six
个人任务: 季方:优化统计团队博客的方法. 马佳慧:选择功能界面的logo.背景与功能选择框的整体设计组合. 司宇航:合并程序(添加打印txt). 王金萱:搭建网络服务器,上传数据库及程序. 站立会议 ...
- 剑指offer:二叉搜索树的后续遍历序列
题目描述: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 解题思路: 根据二叉搜索的性质,后序遍历是先搜索 ...
- We're Chronos! ----- Meet the team 团队作业 #1
Meet Us —————————————————La ligne de séparation————————————————— Kane Lim [林珣玙] < PM, Programmer ...
- wc命令行程序
软件的需求分析 程序处理用户需求的模式为: wc.exe [parameter][filename] 在[parameter]中,用户通过输入参数与程序交互,需实现的功能如下: 1.基本功能 支持 - ...
- VS2013快速安装教程
1.下载vs2013安装镜像.VS2013_RTM_ULT_CHS.iso链接: http://pan.baidu.com/s/1mguOdiK密码: rllz 建议使用百度网盘客户端下载,虽然被人 ...