首页 > 其他分享 >2-SAT

2-SAT

时间:2023-11-09 12:12:53浏览次数:32  
标签:int neg stk maxn low SAT

2-SAT

引子

有 \(2n\) 种药物,分成 \(n\) 对,每种药物恰好属于一对。现有一种治疗方法,每一对药至少吃一种,但有某些药不可以两个一起吃,求任意一种合法的吃药方案。

这样的现实问题可以转换为一个布尔方程组表示,设 \(a\),\(a=1\) 表示吃 \(a\) 种药,\(a=0\) 表示不吃 \(a\) 种药。

在大多数问题中,用 \(a\) 表示 \(a=1\),用 \(\neg a\) 来表示 \(a=0\)。

对于同一对的药,有: \(a=1\) 或 \(a'=1\)。

对于不可以一起吃的药,有:\(a=0\) 或 \(a^{''}=0\)。

即 \(a\) 或 \(a'\) ;\(\neg a\) 或 \(\neg a^{''}\)。

每一个这样的方程都需要成立至少一项。

求解这样的问题便可以使用 2-SAT。

思路

对于一个方程,我们考虑:如果前一项不成立,那么后一项必须成立;后一项不成立,那么前一项必须成立。

把每一个 \(a\) 和 \(\neg a\) 抽象成一个点。

于是对于一个方程 \(a\) 或 \(b\),我们将 \(\neg a\) 到 \(b\) 和 \(\neg b\) 到 \(a\) 连有向边。

这条有向边的含义为:如果取 \(\neg a\) 那么必须取 \(b\);如果取 \(\neg b\) 那么必须取 \(a\)。

对于一张图而言,如果形成了强联通分量,这个强联通分量上的点可以的取值构成一种合法的方案。

强连通的定义是:有向图 G 强连通是指,G 中任意两个结点连通。

强连通分量(SCC)的定义是:极大的强连通子图。

如果 \(a\) 和 \(\neg a\) 在同一个强联通分量内,方程无解。

因为不可以既取 \(a\) 又取 \(\neg a\)。

这里可以使用 Tarjin SCC 缩点(将一个分量缩成一个点),缩完点后,根据拓扑序求取值,如果 \(a\) 在 \(\neg a\) 之后,取 \(a\);反之取 \(\neg a\)。可以证明(根据建图方法),如果每个都取后出现的点,在图有解的情况下,肯定存在一种方案。

CODE

P4782 【模板】2-SAT

#include<bits/stdc++.h>
using namespace std;

const int maxn=2e6+5;

struct node
{
    int to,nxt;
}edge[maxn*2];

int n,m,tot,dfntot,num;
int head[maxn],dfn[maxn],low[maxn],id[maxn];

bool vis[maxn];

stack<int>stk;

void add(int x,int y)
{
    tot++;
    edge[tot].to=y;
    edge[tot].nxt=head[x];
    head[x]=tot;
}

void dfs(int u)
{
    dfn[u]=low[u]=++dfntot,vis[u]=true,stk.push(u);
    for(int i=head[u];i;i=edge[i].nxt)
    {
        int v=edge[i].to;
        if(!dfn[v]) dfs(v),low[u]=min(low[u],low[v]);
        else if(vis[v]) low[u]=min(low[u],dfn[v]);
    }
    if(low[u]==dfn[u])
    {
        num++;
        while(stk.top()!=u) vis[stk.top()]=0,id[stk.top()]=num,stk.pop();
        vis[stk.top()]=0,id[stk.top()]=num;
        stk.pop();
    }
}

int main()
{
    scanf("%d%d",&n,&m);
    for(int i=1;i<=m;i++)
    {
        int x,a,y,b;
        scanf("%d%d%d%d",&x,&a,&y,&b);
        if(a==0&&b==1) swap(x,y),swap(a,b);
        if(a==0&&b==0) add(x,y+n),add(y,x+n);
        else if(a==1&&b==0) add(x+n,y+n),add(y,x);
        else if(a==1&&b==1) add(x+n,y),add(y+n,x);
    }

    for(int i=1;i<=n*2;i++) if(!dfn[i]) dfs(i);

    for(int i=1;i<=n;i++) if(id[i]==id[i+n]) printf("IMPOSSIBLE"),exit(0);
    printf("POSSIBLE\n");
    for(int i=1;i<=n;i++) cout<<(id[i]<id[i+n])<<" ";
}

END……

标签:int,neg,stk,maxn,low,SAT
From: https://www.cnblogs.com/binbinbjl/p/17819410.html

相关文章

  • 迅为3A5000主板,支持PCIE 3.0、USB 3.0和 SATA 3.0显示接口2 路、HDMI 和1路 VGA,可直
    性能强采用全国产龙芯3A5000处理器,基于龙芯自主指令系统(LoongArch@)的LA464微结构,并进一步提升频率,降低功耗,优化性能。桥片桥片采用龙芯7A2000,支持PCIE3.0、USB3.0和SATA3.0显示接口2路、HDMI和1路VGA,可直连显示器;另外内置一个网络PHY,片内集成了自研GPU,搭配32位DDR4显......
  • SATA基础+更改终端颜色+PCI.ids位置+Linux和Windows的scanf+C语言C++的局部变量与全局
    SATA基础https://zhuanlan.zhihu.com/p/554251608物理信号物理层功能时钟恢复:对于高频传输,一般是采用差分信号传输,并且没有单独的时钟,时钟存在于编码内部串并转换:对于高频传输,串联信号可以做到更高的频率。字节对其:8/10编码转换的10bit对其链路层、传输层链路层和传输......
  • 2-SAT
    说是技巧,其实应该是常识。。。2-SAT没学好导致的。首先是一些奇怪的情况。我们假设蓝绿是一组,红黄是一组,椭圆是scc,那么红黄会选黄,蓝绿会选绿,然而绿又能推出红,遂卒。但是这是不可能的。实际上考虑建图时我们干了什么事情。我们建了类似于这样的东西:实际上这两对点是对等......
  • CF600E Lomsat gelral
    树上启发式合并(dsuontree)通常用来查询不带修的子树信息,信息要求可合并。对于一个结点\(u\),其步骤如下:求解其轻儿子的答案,同时清除递归产生的影响。求解其重儿子的答案,保留递归产生的影响。将轻儿子子树内的每个结点都合并进答案中,同时成为以\(u\)为根的子树产生的影响。......
  • 整合satoken鉴权
    依赖<!--核心库--><dependency> <groupId>cn.dev33</groupId> <artifactId>sa-token-spring-boot-starter</artifactId> <version>1.20.0</version></dependency><!--用Redis缓存授权信息--><dependency> &l......
  • 利用windows自带的winsat工具获得硬盘顺序读写速度
    源代码如下:packagetest;importjava.io.BufferedReader;importjava.io.IOException;importjava.io.InputStream;importjava.io.InputStreamReader;importjava.nio.charset.StandardCharsets;importjava.util.regex.Matcher;importjava.util.regex.Pattern;public......
  • [HNOI2010] 平面图判定-平面图性质、带权并查集/2-sat
    [HNOI2010]平面图判定-平面图性质、带权并查集/2-sathttps://www.luogu.com.cn/problem/P3209题意:给一张\(n\)个点,\(m\)条边的哈密顿图,并且哈密顿回路已知,问是否是平面图,\(T\)组询问。\(1\leqT\leq100,1\leqn\leq200,1\leqm\leq10^4\)。转换挺奇妙的。极大平面......
  • P6378 [PA2010] Riddle-2sat优化建图
    P6378[PA2010]Riddle-2sat优化建图\(n\)个点\(m\)条边的无向图被分成\(k\)个部分。每个部分包含一些点。请选择一些关键点,使得每个部分恰有一个关键点,且每条边至少有一个端点是关键点。\(1\leqn,m\leq10^6\)边的限制用\(n\)个变量\(x_1\dotsx_n\),其中\(x_i\)......
  • 文献阅读-We extend the well-established assumption-based interface of incrementa
      Abstract:Weextendthewell-establishedassumption-basedinterfaceofincrementalSATsolverstoclauses,allowingtheadditionofatemporaryclausethathasthesamelifespanasliteralassumptions.Ourapproachisefficientandeasytoimpleme......
  • Landsat 8 Collection 2 Tier 1 calibrated top-of-atmosphere (TOA) reflectance
    Landsat8Collection2Tier1calibratedtop-of-atmosphere(TOA)reflectance.Calibrationcoefficientsareextractedfromtheimagemetadata.See Chanderetal.(2009) fordetailsontheTOAcomputation.Landsatsceneswiththehighestavailabledataqual......