-
Notifications
You must be signed in to change notification settings - Fork 1
/
manacher.cpp
29 lines (29 loc) · 1021 Bytes
/
manacher.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
// Manacher's algorithm: finds maximal palindrome lengths centered around each
// position in a string (including positions between characters) and returns
// them in left-to-right order of centres. Linear time.
// Ex: "opposes" -> [0, 1, 0, 1, 4, 1, 0, 1, 0, 1, 0, 3, 0, 1, 0]
vector<int> fastLongestPalindromes(string str) {
int i=0,j,d,s,e,lLen,palLen=0;
vector<int> res;
while (i < str.length()) {
if (i > palLen && str[i-palLen-1] == str[i]) {
palLen += 2; i++; continue;
}
res.push_back(palLen);
s = res.size()-2;
e = s-palLen;
bool b = true;
for (j=s; j>e; j--) {
d = j-e-1;
if (res[j] == d) { palLen = d; b = false; break; }
res.push_back(min(d, res[j]));
}
if (b) { palLen = 1; i++; }
}
res.push_back(palLen);
lLen = res.size();
s = lLen-2;
e = s-(2*str.length()+1-lLen);
for (i=s; i>e; i--) { d = i-e-1; res.push_back(min(d, res[i])); }
return res;
}