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万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览