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;
}
發佈了44 篇原創文章 · 獲贊 9 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章