トピックリンク
について
[説明]
良いブログのアドレスを入れて、
manacherアルゴリズムは、アイデアは回文文字列対称的な性質を利用することで、おそらくある感じ。
回文文字列の中心として一定のポイントに、使用前に数えました。現在の文字列を列挙するには、その中に含まれています。
結果は、現在の文字列の右の左半分の結果を得るために使用することができます。
(N)O
もちろん、列挙されてもよく、O(N ^ 2)ここで、中間点を見つけることができます。
[コード]
class Solution {
public:
const int N = 1000;
string getSpecialString(string s){
string temp = "#";
int len = s.size();
for (int i = 0;i < len;i++){
temp = temp + s[i];
temp = temp + "#";
}
return temp;
}
string longestPalindrome(string s) {
int p[N*2+10];
memset(p,0,sizeof p);
s = getSpecialString(s);
int ma = -1,id = -1;
int len = s.size();
for (int i = 0;i < len;i++){
if (i>ma){
p[i] = 1;
}else{//i<=ma
//这种情况里面也有可以继续扩展的情况
p[i] = min(ma-i+1,p[2*id-i]);
}
while (i-p[i]>=0 && i+p[i]<len && s[i-p[i]]==s[i+p[i]]){
if (i+p[i]>ma){//更新最右边界
ma = i+p[i];
id = i;
}
p[i]++;
}
}
int ansindex = 0;
for (int i = 1;i < len;i++)
if (p[ansindex]<p[i]){
ansindex = i;
}
string t = "";
for (int i = ansindex-p[ansindex]+1;i<=ansindex+p[ansindex]-1;i++){
if (s[i]!='#'){
t+=s[i];
}
}
return t;
}
};