呜呜~我想半天都不会……解决这个问题,后来看了题解

瓶颈在于这个对立点跟其余跟它字符串相等的点(所谓当前挂在同一个trie节点上的点),如果不暴力连的话总是互相牵连

所以就强制同一个trie节点上的点的父子关系,每个点拆出来,具体可见code的Add_trie。

然后对立点就独立了。

又有问题了?怎么把它独立出来,连它父亲,它儿子好像怎么会多余两个点。

然后就想到把trie'树拆成两棵,出树和入树

总结一下:

本来每个点连向对应trie'的点,每个trie'的点连向该对立点。满足我们的目的(无论子树内还是祖先上下都能由原节点传到对立点)

为了排除u->u':出树中原节点连对应点的父亲,入树中对立点由原树中该点的父亲连入

  • code
#include<stdio.h>
#include<bits/stdc++.h>
using namespace std;
const int N=3e6+5;
const int M=2;
int fa[N],_[N],to[N<<1],head[N],nxt[N<<1],go[N][M],ecnt,ncnt,num;
int n,nn,mark[N],pos[N];
char s[N];
vector<int>V[N];
void add_edge(int u,int v) {nxt[++ecnt]=head[u];to[ecnt]=v;head[u]=ecnt;}
void Insert(int id) {
int u=0,len=strlen(s);
for(int i=0;i<len;i++) {
int d=s[i]-'0';
if(!go[u][d])go[u][d]=++ncnt;
u=go[u][d];
}
V[u].push_back(id);
}
void Add_trie(int u,int fr) {
for(int d=0;d<=1;d++) {
int x=go[u][d],sz,tmp=fr;
if(!x)continue;
for(int j=0;j<V[x].size();j++) {
int y=V[x][j];pos[y]=++num;
fa[pos[y]]=fr;
add_edge(pos[y],fr);add_edge(fr+nn,pos[y]+nn);fr=pos[y];
}
Add_trie(x,fr);fr=tmp;
}
}
void init2() {
for(int i=1;i<=(n<<1);i++) {
int f=fa[pos[i]];
add_edge(i,f),add_edge(pos[i],_[i]),add_edge(i,pos[i]+nn),add_edge(f+nn,_[i]);
}
}
int dfn[N],low[N],Time,st[N],tp,Bl[N],SCC;
bool In_s[N];
void Tarjan(int u) {
In_s[st[++tp]=u]=1;dfn[u]=low[u]=++Time;
for(int i=head[u];i;i=nxt[i]) {
int v=to[i];
if(!dfn[v]) Tarjan(v),low[u]=min(low[u],low[v]);
else if(In_s[v])low[u]=min(low[u],dfn[v]);
}
if(low[u]==dfn[u]) {
++SCC;int v;
do {
v=st[tp--];In_s[v]=0;Bl[v]=SCC;
}while(u!=v);
}
}
bool _rd() {for(int i=1;i<=n;i++)if(Bl[i]==Bl[_[i]])return 0;return 1;}
int main() {
// freopen("data.in","r",stdin);
scanf("%d",&n);num=ncnt=nn=n<<1;num++;nn++;
for(int i=1;i<=n;i++) {
_[i]=i+n,_[i+n]=i;
scanf("%s",s);int len=strlen(s);
bool flag=0;
for(int j=0;j<len;j++)if(s[j]=='?') {
s[j]='0',Insert(i);s[j]='1',Insert(_[i]);flag=1;break;
}
if(flag)continue;
Insert(i);s[0]=s[0]=='0'?'1':'0';Insert(_[i]);add_edge(_[i],i);
}
Add_trie(0,num);
init2();
for(int i=1;i<=num+nn;i++)if(!dfn[i])Tarjan(i);
if(_rd()) printf("YES");
else printf("NO");
return 0;
}

[2-SAT]编码的更多相关文章

  1. 前端学HTTP之实体和编码

    前面的话 每天都有各种媒体对象经由HTTP传送,如图像.文本.影片以及软件程序等.HTTP要确保它的报文被正确传送,识别.提取以及适当处理.为了实现这些目标,HTTP使用了完善的标签来描述承载内容的实 ...

  2. 2.keras实现-->字符级或单词级的one-hot编码 VS 词嵌入

    1. one-hot编码 # 字符集的one-hot编码 import string samples = ['zzh is a pig','he loves himself very much','p ...

  3. (转)x264 编码流程

    转自:http://alphamailpost.blog.163.com/blog/static/20111808120128111160728/ http://www.usr.cc/thread-5 ...

  4. 服务器返回中文乱码的情况(UTF8编码 -> 转化为 SYSTEM_LOCALE 编码)

    服务器乱码 转换使用如下方法 入惨{“msg”} -> utf8编码 -> 转化为 SYSTEM_LOCALE 编码 -> 接受转换后的参数 "sEncoding" ...

  5. DAO层单元测试编码和问题排查

    DAO层单元测试编码和问题排查 SecKillDaoTest .java(注意接口参数使用注解@Parm(“parameter”)) package org.secKill.dao; import o ...

  6. Day 19:Properties配置文件类、打印流(printStream) 、 编码与解码

    Properties(配置文件类): 主要用于生产配置文件与读取配置文件的信息. Properties要注意的细节:  1. 如果配置文件的信息一旦使用了中文,那么在使用store方法生成配置文件的时 ...

  7. Python编码记录

    字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...

  8. URL安全的Base64编码

    Base64编码可用于在HTTP环境下传递较长的标识信息.在其他应用程序中,也常常需要把二进制数据编码为适合放在URL(包括隐藏表单域)中的形式.此时,采用Base64编码不仅比较简短,同时也具有不可 ...

  9. myeclipse学习总结一(在MyEclipse中设置生成jsp页面时默认编码为utf-8编码)

    1.每次我们在MyEclispe中创建Jsp页面,生成的Jsp页面的默认编码是"ISO-8859-1".在这种情况下,当我们在页面中编写的内容存在中文的时候,就无法进行保存.如下图 ...

  10. Base64编码

    Base64编码 写在前面 今天在做一个Android app时遇到了一个问题:Android端采用ASE对称加密的数据在JavaWeb(jre1.8.0_7)后台解密时,居然解密失败了!经过测试后发 ...

随机推荐

  1. python-使用函数求特殊a串数列和

    给定两个均不超过9的正整数a和n,要求编写函数fn(a,n) 求a+aa+aaa++⋯+aa⋯aa(n个a)之和,fn须返回的是数列和 函数接口定义: 1 fn(a,n) 2 其中 a 和 n 都是用 ...

  2. 【Android开发】Android工程打压缩包技巧

    android studio的: ".gradle" "*/.gradle" ".idea" "*/.idea" &qu ...

  3. 给一个非矩形数组(Nonrectangular Arrays)

    Nonrectangular Arrays(非矩形数组)  public class Test {     public static void main(String[] args) {       ...

  4. 基于express框架的留言板实现步骤

    这个留言板是基于express框架,和ejs模板引擎,首先需要在根目录安装express框架,然后安装ejs模块和body-parser(获取用户表单提交的数据):建立项目目录 message,然后依 ...

  5. 单位ren vw vh 和 vm

    px: (像素)就是一张图片最小的一个点 em :参考物是父元素的font-size,具有继承的特点 rem: 参考物是HTML的font-size

  6. FastAPI(六十九)实战开发《在线课程学习系统》接口开发--修改密码

    之前我们分享了FastAPI(六十八)实战开发<在线课程学习系统>接口开发--用户 个人信息接口开发.这次我们去分享实战开发<在线课程学习系统>接口开发--修改密码 我们梳理一 ...

  7. caioj 1000到1030都是[水题]

    caioj 1000到1030都是[水题],特此声明一下,可以不做就不要浪费时间做了

  8. python---用顺序表实现栈

    class Stack(object): """栈, 存放数据的一种容器, 后进先出""" def __init__(self): self ...

  9. Java的虚拟线程(协程)特性开启预览阶段,多线程开发的难度将大大降低

    高并发.多线程一直是Java编程中的难点,也是面试题中的要点.Java开发者也一直在尝试使用多线程来解决应用服务器的并发问题.但是多线程并不容易,为此一个新的技术出现了,这就是虚拟线程. 传统多线程的 ...

  10. v-if 和 v-show 的区别

    1.v-if && v-else && v-else-if <span v-if = "4 > 9">hello</span ...