码迷,mamicode.com
首页 > 编程语言 > 详细

HDU-3068-最长回文 (Manacher算法)

时间:2016-01-17 17:29:11      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:

Problem Description
给出一个仅仅由小写英文字符a,b,c...y,z组成的字符串S,求S中最长回文串的长度.
回文就是正反读都是一样的字符串,如aba, abba等
 

Input
输入有多组case,不超过120组,每组输入为一行小写英文字符a,b,c...y,z组成的字符串S
两组case之间由空行隔开(该空行不用处理)
字符串长度len <= 110000
 

Output
每一行一个整数x,相应一组case,表示该组case的字符串中所包括的最长回文长度.
 

Sample Input
aaaa abab
 

Sample Output
4 3


思路:这里讲得非常具体了http://blog.csdn.net/ggggiqnypgjg/article/details/6645824


#include <cstdio>
using namespace std;

char s[110005],str[220010];
int p[220010];

int main()
{
    int len,i,maxlen,maxindex,ans;

    while(~scanf("%s",s))
    {
        str[0]=‘$‘;
        str[1]=‘#‘;

        for(i=0;s[i];i++)
        {
            str[i*2+2]=s[i];
            str[i*2+3]=‘#‘;
        }

        len=i*2+2;
        str[len]=‘\0‘;

        maxlen=0;
        for(i=1;i<len;i++)
        {
            if(maxlen>i) p[i]=p[2*maxindex-i]<maxlen-i?p[2*maxindex-i]:maxlen-i;
            else p[i]=1;

            while(str[i-p[i]]==str[i+p[i]])
            {
                p[i]++;
            }

            if(p[i]+i>maxlen)
            {
                maxlen=p[i]+i;
                maxindex=i;
            }
        }

        ans=0;
            
        for(i=1;i<len;i++) if(ans<p[i]) ans=p[i];

        printf("%d\n",ans-1);
    }
}


HDU-3068-最长回文 (Manacher算法)

标签:

原文地址:http://www.cnblogs.com/yxwkf/p/5137439.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!