poj_3974 Palindrome(最长回文子串)

【题目】

点击这里

【思路】

直接运用Manacher算法。

【代码】

#include <stdio.h>
#include <string.h>
#define maxSize 1000005
#define min(x,y) (x<y)? x:y

char str[maxSize], s[maxSize*2+3];
long int r[maxSize*2+3];

long int manacher()
{
    long int i,len=strlen(str);
    s[0]='$'; s[len*2+1]='#'; s[len*2+2]='*';
    for (i=0;i<len;i++) {s[2*i+1]='#'; s[2*i+2]=str[i];}

    long int j=1; r[1]=1;
    for (i=2;i<=len*2;i++)
    {
        if (r[j]+j>i) r[i]=min(r[j]+j-i, r[2*j-i]); else r[i]=1;
        while (s[i-r[i]]==s[i+r[i]]) r[i]++;
        if (i+r[i]>j+r[j]) j=i;
    }

    long int ans=0;
    for (i=1;i<=len*2;i++) if (r[i]>ans) ans=r[i];
    return ans-1;
}

int main()
{
    int i;
    for (i=1;;i++)
    {
        scanf("%s",str);
        if (strcmp(str,"END")==0) break;
        printf("Case %d: %d\n",i,manacher());
    }
    return 0;
}

你可能感兴趣的:(算法,字符串,poj,最长回文子串,Manacher)