1 Star 0 Fork 0

JJustRight/ACM-ICPC-Algorithms

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
suffix_automaton.cpp 1.15 KB
一键复制 编辑 原始数据 按行查看 历史
Yazan Rihani 提交于 2018-10-06 22:06 +08:00 . Add suffix automaton
struct state
{
int len, link;
map<char, int> next;
};
const int N = 300000 + 5;
struct SA
{
state st[2 * N];
int fpos[2 * N];
int sz, last;
void sa_init()
{
sz = last = 0;
st[0].len = 0;
st[0].link = -1;
++sz;
}
void sa_extend(char c)
{
int cur = sz++;
st[cur].len = st[last].len + 1;
fpos[cur] = st[cur].len - 1;
int p;
for(p = last; p != -1 && !st[p].next.count(c); p = st[p].link)
st[p].next[c] = cur;
if(p == -1)
st[cur].link = 0;
else
{
int q = st[p].next[c];
if(st[p].len + 1 == st[q].len)
st[cur].link = q;
else
{
int clone = sz++;
st[clone].len = st[p].len + 1;
st[clone].next = st[q].next;
st[clone].link = st[q].link;
fpos[clone] = fpos[q];
for(; p != -1 && st[p].next[c] == q; p = st[p].link)
st[p].next[c] = clone;
st[q].link = st[cur].link = clone;
}
}
last = cur;
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/jjustright/ACM-ICPC-Algorithms.git
git@gitee.com:jjustright/ACM-ICPC-Algorithms.git
jjustright
ACM-ICPC-Algorithms
ACM-ICPC-Algorithms
master

搜索帮助