1089 最长回文子串 V2(Manacher算法)
基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题
回文串是指aba、abba、cccbccc、aaaa这种左右对称的字符串。
输入一个字符串Str,输出Str里最长回文子串的长度。
Input
输入Str(Str的长度 <= 100000)
Output
输出最长回文子串的长度L。
Input示例
daabaac
Output示例
5
#include<bits/stdc++.h>
using namespace std;
const int maxn=100000*2+4;
char str[maxn],a[maxn];
int p[maxn];
void pk(int n)
{
int i;
int mx = 0;
int id;
for(i=1; i<n; i++)
{
if( mx > i )
p[i] = min( p[2*id-i], mx-i );
else
p[i] = 1;
for(; str[i+p[i]] == str[i-p[i]]; p[i]++)
;
if( p[i] + i > mx )
{
mx = p[i] + i;
id = i;
}
}
}
int main()
{
int n,i,j,l,ans,len;
while(cin>>a){
ans=0;
len=strlen(a);
str[0]='$';
str[1]='#';
l=2;
for(i=0;i<len;i++) {
str[l++]=a[i];
str[l++]='#';
}
pk(l);
for(i=0;i<l;i++) {
ans=max(ans,p[i]);
}
cout<<ans-1<<endl;
}
return 0;
}