luoguP4112 [HEOI2015]最短不公共子串

链接

luogu

loj

思路

子串可以用后缀自动机,子序列可以用序列自动机。

序列自动机是啥,就是能访问到所有子序列的自动机。

每个点记录下一个字母最近出现的位置。不过我这里构造是\(O(n^2)\)。

然后进行bfs进行广搜就行了。

注意vis[][]剪枝,要不TLE。

代码

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N=2000+7;
int n,m;
struct node {
int len,fa,ch[26];
}dian[4][N<<1];
int las[4]={1,1,1,1},tot[4]={1,1,1,1};
void add(int c,int who) {
int p=las[who];int np=las[who]=++tot[who];
dian[who][np].len=dian[who][p].len+1;
for(;p&&!dian[who][p].ch[c];p=dian[who][p].fa) dian[who][p].ch[c]=np;
if(!p) dian[who][np].fa=1;
else {
int q=dian[who][p].ch[c];
if(dian[who][q].len==dian[who][p].len+1) dian[who][np].fa=q;
else {
int nq=++tot[who];
dian[who][nq]=dian[who][q];
dian[who][nq].len=dian[who][p].len+1;
dian[who][q].fa=dian[who][np].fa=nq;
for(;p&&dian[who][p].ch[c]==q;p=dian[who][p].fa)
dian[who][p].ch[c]=nq;
}
}
}
struct edge{char s[N];}a,b;
int vis[N<<1][N<<1],flag;
void bfs(int T_T,int QwQ) {
queue<pair<pair<int,int>,int> > q;
q.push(make_pair(make_pair(1,1),1));
while(!q.empty()) {
pair<pair<int,int>,int> u=q.front();
node lj1=dian[T_T][u.first.first],lj2=dian[QwQ][u.first.second];
q.pop();
for(int i=0;i<26;++i) {
if(lj1.ch[i]&&!lj2.ch[i])
return printf("%d\n",u.second),void();
if(lj1.ch[i]&&lj2.ch[i]&&vis[lj1.ch[i]][lj2.ch[i]]!=flag) {
q.push(make_pair(make_pair(lj1.ch[i],lj2.ch[i]),u.second+1));
vis[lj1.ch[i]][lj2.ch[i]]=flag;
}
}
}
puts("-1");
}
int main() {
scanf("%s%s",a.s,b.s);
n=strlen(a.s),m=strlen(b.s);
for(int i=0;i<n;++i) add(a.s[i]-'a',0);
for(int i=0;i<m;++i) add(b.s[i]-'a',1);
//build a
for(int i=0;i<n;++i)
if(!dian[2][1].ch[a.s[i]-'a'])
dian[2][1].ch[a.s[i]-'a']=i+2;
for(int i=0;i<n;++i)
for(int j=i+1;j<n;++j)
if(!dian[2][i+2].ch[a.s[j]-'a'])
dian[2][i+2].ch[a.s[j]-'a']=j+2;
//build b
for(int i=0;i<m;++i)
if(!dian[3][1].ch[b.s[i]-'a'])
dian[3][1].ch[b.s[i]-'a']=i+2;
for(int i=0;i<m;++i)
for(int j=i+1;j<m;++j)
if(!dian[3][i+2].ch[b.s[j]-'a'])
dian[3][i+2].ch[b.s[j]-'a']=j+2;
flag++,bfs(0,1);
flag++,bfs(0,3);
flag++,bfs(2,1);
flag++,bfs(2,3);
return 0;
}

luoguP4112 [HEOI2015]最短不公共子串 SAM,序列自动机,广搜BFS的更多相关文章

  1. bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp)

    bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp) bzoj Luogu 题解时间 给两个小写字母串 $ A $ , $ B $ ,请你计算: ...

  2. 【BZOJ4032】[HEOI2015]最短不公共子串(后缀自动机,序列自动机)

    [BZOJ4032][HEOI2015]最短不公共子串(后缀自动机,序列自动机) 题面 BZOJ 洛谷 题解 数据范围很小,直接暴力构建后缀自动机和序列自动机,然后直接在两个自动机上进行\(bfs\) ...

  3. bzoj4032: [HEOI2015]最短不公共子串(SAM+DP)

    4032: [HEOI2015]最短不公共子串 题目:传送门 题解: 陈年老题良心%你赛膜爆嘎爷 当初做题...一眼SAM...结果只会两种直接DP的情况... 情况1: 直接设f[i][j] 表示的 ...

  4. BZOJ4032:[HEOI2015]最短不公共子串(SAM)

    Description 在虐各种最长公共子串.子序列的题虐的不耐烦了之后,你决定反其道而行之. 一个串的“子串”指的是它的连续的一段,例如bcd是abcdef的子串,但bde不是. 一个串的“子序列” ...

  5. BZOJ4032: [HEOI2015]最短不公共子串(后缀自动机+序列自动机)

    题目描述 在虐各种最长公共子串.子序列的题虐的不耐烦了之后,你决定反其道而行之. 一个串的“子串”指的是它的连续的一段,例如bcd是abcdef的子串,但bde不是. 一个串的“子序列”指的是它的可以 ...

  6. BZOJ4032 [HEOI2015]最短不公共子串 【后缀自动机 + 序列自动机 + dp】

    题目链接 BZOJ4032 题解 首先膜\(hb\) 空手切神题 一问\(hash\),二问枚举 三问\(trie\)树,四问\(dp\) 南二巨佬神\(hb\) 空手吊打自动机 \(orz orz ...

  7. BZOJ.4032.[HEOI2015]最短不公共子串(DP 后缀自动机)

    题目链接 1.求A的最短子串,它不是B的子串. 子串是连续的,对B建SAM,枚举起点,在SAM上找到第一个无法匹配点即可.O(n)用SAM能做吗..开始想错了. 2.求A的最短子串,它不是B的子序列. ...

  8. BZOJ 4032: [HEOI2015]最短不公共子串

    4032: [HEOI2015]最短不公共子串 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 446  Solved: 224[Submit][Sta ...

  9. 洛谷 P4112 [HEOI2015]最短不公共子串 解题报告

    P4112 [HEOI2015]最短不公共子串 题目描述 在虐各种最长公共子串.子序列的题虐的不耐烦了之后,你决定反其道而行之. 一个串的"子串"指的是它的连续的一段,例如bcd是 ...

随机推荐

  1. 动画重定向技术分析及其在Unity中的应用

    前言 笔者新的手游项目使用Unity引擎,动画部分要使用重定向技术来实现动画复用.笔者之前在大公司工作的时候对这块了解比较深入,读过Havok引擎在这部分的实现源码,并基于自己的理解,在公司自研的手游 ...

  2. Linux环境:VMware下windows虚拟机与linux主机进行文件共享的方法

    操作主要分两大步骤: 一.是对主机进行配置: 二.是在虚拟机上直接连接共享目录. 一.主机配置 1.打开VMware虚拟机,双击需要进行文件共享的虚拟机.如下图,双击CentOS 64位(以linux ...

  3. dubbo循序渐进 - nacos安装

    1.安装docker ce yum install -y yum-utils device-mapper-persistent-data lvm2 yum-config-manager --add-r ...

  4. English--并列句

    English|并列句 现在开始讲解英语中的最简单的长句,即并列句. 前言 目前所有的文章思想格式都是:知识+情感. 知识:对于所有的知识点的描述.力求不含任何的自我感情色彩. 情感:用我自己的方式, ...

  5. elementUi vue el-radio 监听选中变化

    //change是radio-group标签的事件 <div> <el-radio-group v-model="radioSex" @change=" ...

  6. Python的矩阵传播机制&矩阵运算

    Python的矩阵传播机制(Broadcasting) 最近在学习神经网络.我们知道在深度学习中经常要操作各种矩阵(matrix).回想一下,我们在操作数组(list)的时候,经常习惯于用for循环( ...

  7. jq 实现切换菜单选中状态

    点击导航菜单,切换选中状态 效果: 思路:首先获取选中的URL,再通过正则判断是否相同,相同就加上相应的属性,不相同就去除相应的属性. html代码 <div class="layui ...

  8. PHP在无限分类时注意的一些问题(不保证代码完全正确哦)

    转自:PHP在无限分类时注意的一些问题(http://lxiaoke.cn) (注意:代码使用的是原生PHP,旨在提供解决思路)1 无限分类的查找(获取所有节点) 代码: /** * 无限分类查询,默 ...

  9. excel 大文件解析原理实现

    问题 目前的excel 不像之前的excel了可以支持的数据量更大,可以支持支持1048576行,16384列. 之前使用poi读取,直接报错,使用excel 事件的方式读取,还有不少的bug,关键是 ...

  10. 【Yellow Cards CodeForces - 1215A 】【贪心】

    该题难点在于求最小的离开数,最大的没什么好说的,关键是求最小的. 可以这样去想,最小的离开数就是每个人获得的牌数等于他所能接受的最大牌数-1,这样就可以直接比较m=a1(k1-1)+a2(k2-1)与 ...