SPOJ LCS2 后缀自动机

时间:2023-02-05 12:18:23

多串的LCS,注意要利用拓扑序更新suf的len。

我用min,max,三目会超时,所以都改成了if,else

#pragma warning(disable:4996)
#include<cstring>
#include<string>
#include<iostream>
#include<cmath>
#include<vector>
#include<algorithm>
#define maxn 100050
using namespace std; struct State{
State *suf, *go[26];
int val, len[2];
State() :suf(0), val(0){
memset(go, 0, sizeof(go));
memset(len, 0, sizeof(len));
}
}*root, *last; State statePool[maxn * 2], *cur; void init()
{
cur = statePool;
root = last = cur++;
} void extend(int w)
{
State *p = last, *np = cur++;
np->val = p->val + 1;
np->len[1] = np->val;
while (p&&!p->go[w]) p->go[w] = np, p = p->suf;
if (!p) np->suf = root;
else{
State *q = p->go[w];
if (p->val + 1 == q->val){
np->suf = q;
}
else{
State *nq = cur++;
memcpy(nq->go, q->go, sizeof q->go);
nq->val = p->val + 1;
nq->len[1] = nq->val;
nq->suf = q->suf;
q->suf = nq;
np->suf = nq;
while (p&&p->go[w] == q){
p->go[w] = nq, p = p->suf;
}
}
}
last = np;
} char str[maxn];
int n; int bcnt[maxn];
State *b[maxn * 2]; int main()
{
n = 0;
scanf("%s", str);
init();
int len = strlen(str);
for (int i = 0; i < len; i++){
extend(str[i] - 'a');
}
int tot = cur - root;
memset(bcnt, 0, sizeof(bcnt));
for (int i = 0; i < tot; i++) bcnt[statePool[i].val]++;
for (int i = 1; i <= len; i++) bcnt[i] += bcnt[i - 1];
for (int i = tot - 1; i >= 0; i--) b[--bcnt[statePool[i].val]] = &statePool[i];
while (scanf("%s", str) != EOF){
int lenb = strlen(str);
int cnt = 0;
State *p = root;
for (int i = 0; i < lenb; i++){
if (p->go[str[i] - 'a']){
cnt++;
p = p->go[str[i] - 'a'];
}
else{
while (p&&!p->go[str[i] - 'a']) p = p->suf;
if (!p) {
p = root;
cnt = 0;
}
else{
cnt = p->val + 1;
p = p->go[str[i] - 'a'];
}
}
if (cnt > p->len[0]){
p->len[0] = cnt;
}
}
for (int i = tot - 1; i >= 0; i--){
if (b[i]->len[0]<b[i]->len[1]) b[i]->len[1] = b[i]->len[0];
if (b[i]->suf&&b[i]->suf->len[0]< b[i]->len[0]){
b[i]->suf->len[0] = b[i]->len[0];
}
b[i]->len[0] = 0;
}
}
int ans = 0;
for (int i = 0; i < tot; i++){
if (ans < b[i]->len[1]){
ans = b[i]->len[1];
}
}
printf("%d\n", ans);
return 0;
}

SPOJ LCS2 后缀自动机的更多相关文章

  1. 多个串的最长公共子串 SPOJ - LCS2 后缀自动机

    题意: 求多个串的最长公共子串 这里用的是O(n)的后缀自动机写法 我后缀数组的专题有nlog(n)写法的 题解: 对于其中的一个串建立后缀自动机 然后对于后缀自动机上面的每一个节点求出每一个节点最长 ...

  2. SPOJ NSUBSTR &lpar;后缀自动机&rpar;

    SPOJ NSUBSTR Problem : 给一个长度为n的字符串,要求分别输出长度为1~n的子串的最多出现次数. Solution :首先对字符串建立后缀自动机,在根据fail指针建立出后缀树,对 ...

  3. SPOJ LCS 后缀自动机

    用后缀自动机求两个长串的最长公共子串,效果拔群.多样例的时候memset要去掉. 解题思路就是跟CLJ的一模一样啦. #pragma warning(disable:4996) #include&lt ...

  4. SPOJ - LCS 后缀自动机入门

    LCS - Longest Common Substring A string is finite sequence of characters over a non-empty finite set ...

  5. SPOJ LCS 后缀自动机找最大公共子串

    这里用第一个字符串构建完成后缀自动机以后 不断用第二个字符串从左往右沿着后缀自动机往前走,如能找到,那么当前匹配配数加1 如果找不到,那么就不断沿着后缀树不断往前找到所能匹配到当前字符的最大长度,然后 ...

  6. SPOJ 7258 &lpar;后缀自动机&rpar;

    转载:http://hzwer.com/4492.html 给一个长度不超过90000的串S,每次询问它的所有不同子串中,字典序第K小的,询问不超过500个. 搞出后缀自动机 dp处理出每个点往下走能 ...

  7. 长度为x的本质不同的串的出现次数 SPOJ - NSUBSTR 后缀自动机简单应用

    题意: 长度为x的本质不同的串的出现次数 题解: 先处理出每一个节点所对应的子串出现的次数 然后取max就好了 #include <set> #include <map> #i ...

  8. SPOJ&period;1812&period;LCS2&lpar;后缀自动机&rpar;

    题目链接 \(Description\) 求最多10个串的LCS(最长公共子序列). \(Solution\) 类比上题,对一个串建SAM,我们可以逐串地求出其在每个节点所能匹配的最大长度mx[i]. ...

  9. SPOJ 1812 LCS2 &lbrack;后缀自动机 DP&rsqb;

    题意: 求多个串<=10的最长连续子串 一个串建SAM,然后其他串在上面走 每个状态记录所有串在这个状态的公共子串的最小值 一个串在上面走的时候记录与每个状态公共子串的最大值,注意出现次数向父亲 ...

随机推荐

  1. 使用T4模板生成不同部署环境下的配置文件

    在开发企业级应用的时候,通常会有不同的开发环境,比如有开发环境,测试环境,正式环境,生产环境等.在一份代码部署到不同环境的时候,不同环境的配置文件可能需要根据目标环境不同而不同.比如在开发环境中,数据 ...

  2. javascript练习-子类调用父类的构造函数和方法

    function NonNullSet(){ Set.apply(this,arguments); } NonNullSet.prototype = inherit(Set.prototype); N ...

  3. 解决360、猎豹浏览器等极速模式下css3兼容问题

    有时候你会发现你写的animation动画的css3效果,在IE.谷歌.火狐等主流的新版本的浏览器的是没有什么兼容问题的,即便你不写前缀,也是可以显示动画效果的.然后,你本地在360浏览器或猎豹浏览器 ...

  4. 《iOS开发指南》要改iOS8版本了,听听您的意见?

    <iOS开发指南>要改iOS8版本了,听听您的意见?参加问卷同学均可获得智捷课堂50元代金卡一张,同时抽取一名同学赠送即将出版的基于iOS8的<iOS开发指南>一本,欢迎大家填 ...

  5. hdu 1005 java&lpar;System&period;out&period;println&lpar;&rpar;&semi;与System&period;out&period;println&lpar;&OpenCurlyDoubleQuote;&bsol;n”&rpar;&semi;&rpar;

    //package Main; import java.util.Scanner; public class Main { static int [][] mat=new int [2][2]; st ...

  6. C&num;用副线程改主线程(UI线程)的控件属性的方法(包括Winform和WPF)

    C#用副线程去试图修改主线程的UI控件会报出异常,解决方案是使用副线程注册事件通知主线程自己去修改UI控件 在winform中,方法如下 private void button1_Click(obje ...

  7. git的使用说明详解

    http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/001375840202368c7 ...

  8. Linux部署ASP&period;NET 5 &lpar;vNext&rpar;

    原文:Linux部署ASP.NET 5 (vNext) ASP.NET 5 (vNext) Linux部署   引言 工欲善其事,必先利其器. 首先,我们先明确下以下基本概念 Linux相关 Ubun ...

  9. the c programing language 学习过程7

    interact 互动 carriage运费运输 linefeed 换行 redirection改方向 interleaved交叉存取 adequate足够的 untouched原样的  specif ...

  10. Maven配置ojdbc14-10&period;2&period;0&period;4&period;0&period;jar

    对于oralce的jdbc驱动,在maven上搜索到把pom配置复制到pom.xml里进行引用的时候出现下面这种情况 <dependency> <groupId>com.ora ...