forked from Errichto/contest_library
-
Notifications
You must be signed in to change notification settings - Fork 0
/
text_algorithms.cpp
66 lines (64 loc) · 1.56 KB
/
text_algorithms.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
vector<int> kmp (string & s)
{
vector<int>P;
P.push_back(0);
int t=0;
for(int i=1;i<(int)s.length();i++)
{
while(t>0 && s[t]!=s[i])
t=P[t-1];
if(s[t]==s[i])
t++;
P.push_back(t);
}
return P;
}
vector<int> suffix_array(string & s)
{
int k=0;
vector<int> labels;
for(string :: iterator i = s.begin();i!=s.end();i++)
labels.push_back((int)*i);
while(1 << k < (int)s.length())
{
vector<pair<pair<int,int>,int > > tmp;
for(int i = 0; i < (int)s.length();i++)
tmp.push_back(make_pair(make_pair(labels[i],i+(1<<k) < (int)s.length() ? labels[i+(1<<k)] : 1<<30),i));
sort(tmp.begin(),tmp.end());
int l=0;
for(int i=0;i <(int) tmp.size();i++)
{
if(i>0 && tmp[i].first!= tmp[i-1].first)
l++;
labels[tmp[i].second]=l;
}
k++;
}
vector<int> sa;
sa.resize(s.length());
for(int i=0;i <(int) labels.size();i++)
sa[labels[i]]=i;
return sa;
}
vector<int> lcp(string & s,vector<int> & sa)
{
vector<int> lcp,rank;
rank.resize(sa.size());
lcp.resize(sa.size());
for(int i=0;i<sa.size();i++)
rank[sa[i]]=i;
int l=0;
for(int i=0;i<sa.size();i++)
{
if(rank[i]==sa.size()-1)
lcp[rank[i]]=0;
else
{
while(i+l < s.length() && sa[rank[i]+1]+l < s.length() && s[i+l]==s[sa[rank[i]+1]+l])
l++;
lcp[rank[i]]=l;
}
l=max(0,l-1);
}
return lcp;
}