“写sam是肯定会去写的,这样才学的了字符串,后缀数组又不会用 >ω<,

sam套上数据结构的感觉就像回家一样!

里面又能剖分又能线段树合并,调试又好调,我爱死这种写法了 !qwq”

SAM是一个DFA,它存储了某字符串的所有子串信息。

待更。

博主水平不行,尽量在退役前多更些。

插入字符:

 void extend(int id,int&now)
{
int p=now;
if(ch[p][id] && len[ch[p][id]]==len[p]+)
{
now=ch[p][id];
return;
}
int np=++tot;
len[np]=len[p]+;
while(p && !ch[p][id])
{
ch[p][id]=np;
p=fa[p];
}
if(!p)
{
fa[np]=;
}
else
{
int q=ch[p][id];
if(len[q]==len[p]+)
{
fa[np]=q;
}
else
{
int nq=++tot;
len[nq]=len[p]+;
fa[nq]=fa[q];
for(int i=;i<;i++)
ch[nq][i]=ch[q][i];
fa[q]=fa[np]=nq;
while(p && ch[p][id]==q)
{
ch[p][id]=nq;
p=fa[p];
}
}
}
now=np;
}

套路:

每条路径与子串一一对应。

$len_i$:该节点最长串的长度

$Parent Tree$上的子树和:串的出现次数

$len_i - len_{fa_i}$:该节点代表的串的数目

部分题目选:

(1)[SAM入门题][NOI2018]你的名字

题目链接

线段树合并维护$right$集合

(2)[SAM入门题][CTSC2012]熟悉的文章

题目链接

$SAM$只是用来预处理的,求答案还要靠二分+单队$DP$

(3)[SAM入门题][bzoj2555]Substring

题目链接

$LCT$对$Parent Tree$结构的维护

(4)[bzoj3277]字符串

题目链接

广义后缀自动机的应用

暴力搞复杂度大概是根号的,不会证明。

(5)[bzoj5084]HASHIT

题目链接

带撤销后缀自动机,随机数据随便艹。

upd:BFS建树形后缀树以后再进行DFS+树链求并统计答案就行了。

(6)[USACO]牛奶模式

题目链接

后缀自动机的基本原理与使用

(7)[洛谷元旦赛]WD与数列

题目链接

维护$right$集合的好题(似乎还要在parent树上跑启发式合并计算贡献,我并不会)

现在可能会了。

(8)[FZOJ2258]封印

校内题目,没连接

大概就是你知道$Parent$树是干啥的,形态如何,就能直接切掉。

(9)[TJOI2016]字符串

考虑求出 sam 上一个串 p 在 [l,r] 里出现的次数,这个可以通过数一数 p 的 right 集合里有多少在 $[l+len_p-1,r]$ 中出现。

lcp 可以二分,倍增可以从区间 locate 子串,那么这个题就 $O(n\log^2 n)$ 了。

upd:话说为啥没见过把状态设在sam节点上的DP题?

upd:CF700E,已经单独更新

(10)[十二省联考]字符串问题

题目意思大概是描述给你一个连边关系,求 DAG 上最长路。

直接暴力构图可以 $n^2$ ,用 hash 判断。

如果考虑建后缀树,那么在一个节点上有短->长的后缀关系,另外父子关系也是后缀关系,拆点据此连边即可。

只需要实现对区间 locate 子串即可,时间复杂度 $O(n\log n)$。

SAM(后缀自动机)总结的更多相关文章

  1. Distinct Substrings(spoj694)(sam(后缀自动机)||sa(后缀数组))

    Given a string, we need to find the total number of its distinct substrings. Input \(T-\) number of ...

  2. 弦论(tjoi2015,bzoj3998)(sam(后缀自动机))

    对于一个给定长度为\(N\)的字符串,求它的第\(K\)小子串是什么. Input 第一行是一个仅由小写英文字母构成的字符串\(S\) 第二行为两个整数\(T\)和\(K\),\(T\)为0则表示不同 ...

  3. LCS2 - Longest Common Substring II(spoj1812)(sam(后缀自动机)+多串LCS)

    A string is finite sequence of characters over a non-empty finite set \(\sum\). In this problem, \(\ ...

  4. LCS - Longest Common Substring(spoj1811) (sam(后缀自动机)+LCS)

    A string is finite sequence of characters over a non-empty finite set \(\sum\). In this problem, \(\ ...

  5. Lexicographical Substring Search (spoj7259) (sam(后缀自动机)+第k小子串)

    Little Daniel loves to play with strings! He always finds different ways to have fun with strings! K ...

  6. Substrings(SPOJ8222) (sam(后缀自动机))

    You are given a string \(S\) which consists of 250000 lowercase latin letters at most. We define \(F ...

  7. sam(后缀自动机)

    后缀自动机ins解释 void ins(int c){ int p=last;//将当前节点的parent节点变为last int np=++cnt;//建立新节点 last=np;//将last设为 ...

  8. Luogu P3346 [ZJOI2015]诸神眷顾的幻想乡 广义SAM 后缀自动机

    题目链接 \(Click\) \(Here\) 真的是好题啊-不过在说做法之前先强调几个自己总是掉的坑点. 更新节点永远记不住往上跳\(p = fa[p]\) 新建节点永远记不住\(len[y] = ...

  9. 字符串(tjoi2016,heoi2016,bzoj4556)(sam(后缀自动机)+线段树合并+倍增+二分答案)

    佳媛姐姐过生日的时候,她的小伙伴从某东上买了一个生日礼物.生日礼物放在一个神奇的箱子中.箱子外边写了 一个长为\(n\)的字符串\(s\),和\(m\)个问题.佳媛姐姐必须正确回答这\(m\)个问题, ...

  10. 后缀自动机SAM学习笔记

    前言(2019.1.6) 已经是二周目了呢... 之前还是有一些东西没有理解到位 重新写一下吧 后缀自动机的一些基本概念 参考资料和例子 from hihocoder DZYO神仙翻译的神仙论文 简而 ...

随机推荐

  1. C语言合法标识符 题解

    输入一个字符串,判断其是否是C的合法标识符.  Input输入数据包含多个测试实例,数据的第一行是一个整数n,表示测试实例的个数,然后是n行输入数据,每行是一个长度不超过50的字符串. Output对 ...

  2. django入门与实践(开)

    1.什么是Django? 基于python的高级web开发框架 高效 快速 免费 开源 正常上网流程 浏览器浏览网页的基本原理 请求响应过程 开发环境搭建 Python Django pip inst ...

  3. JS字符串的不可变性

    js中的字符串特性->不可变性,字符串的值是不可变的 1.改变字符串中的字符 var str = "hello"; str[1] = "W"; conso ...

  4. IntelliJ IDEA 2017.3尚硅谷-----自动导包

  5. Windows Server 2008 R2远程桌面服务安装配置和授权激活

    1.安装 2.远程桌面授权激活 2.1 管理工具——远程桌面服务——(远程桌面授权管理)RD授权管理器: 2.2 由于RD授权服务器还未激活,所以授权服务器图标右下角显示红色×号: 点服务器展开——右 ...

  6. Codeforces Round #599 (Div. 2) B2. Character Swap (Hard Version)

    This problem is different from the easy version. In this version Ujan makes at most 2n2n swaps. In a ...

  7. Go流程结构(if)

    一.程序的流程结构 程序的流程控制结构一共有三种:顺序结构,选择结构,循环结构. 顺序结构:从上向下,逐行执行. 选择结构:条件满足,某些代码才会执行.0-1次 分支语句:if,switch,sele ...

  8. oracle增加字段,循环

    alter table PARAMETETER_CONFIGURATION add (INPUT_IS VARCHAR2(20) ): declare sum_i int:=0; --定义整型变量,存 ...

  9. Linux创建连接命令 ln -s创建软连接

    ln -s 是linux中一个非常重要命令,一定要熟悉.它的功能是为某一个文件在另外一个位置建立一个同不的链接,这个命令最常用的参数是-s, 具体用法是:ln -s 源文件 目标文件. 当 我们需要在 ...

  10. Linux编程日常错误

    编译的时候出现如下错误提示: undefined reference to `sem_init'undefined reference to `sem_post'undefined reference ...