hdu3068 最长回文 马拉车模板题

Posted mountaink

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hdu3068 最长回文 马拉车模板题相关的知识,希望对你有一定的参考价值。

题目传送门

马拉车算法模板题。

 

        学习博客

技术图片
#include<bits/stdc++.h>
#define clr(a,b) memset(a,b,sizeof(a))
using namespace std;
typedef long long ll;
const int maxn=110010;
char s[maxn<<1],ne[maxn<<1];
int p[maxn<<1],mx,maxx;
int init(){
    int len=strlen(s),j=0;
    ne[0]=$;
    ne[1]=#;
    j=2;
    for(int i=0;i<len;i++)
    {
        ne[j++]=s[i];
        ne[j++]=#;
    }
    ne[j]=;
    return j;
}
int Manacher(){
    int len=init();
    int id;
    mx=0;
    for(int i=1;i<=len;i++)
    {
        if(i<mx){
            p[i]=min(p[2*id-i],mx-i);
        }else p[i]=1;
        while(ne[i-p[i]]==ne[i+p[i]])p[i]++;
        if(mx<i+p[i]){
            mx=i+p[i];
            id=i;
        }
        maxx=max(maxx,p[i]);
    }
    return maxx;
}
int main(){
    while(scanf("%s",s)!=EOF){
        maxx=0;
        Manacher();
        cout<<maxx-1<<endl;
    }
}
View Code

 

以上是关于hdu3068 最长回文 马拉车模板题的主要内容,如果未能解决你的问题,请参考以下文章

hdu 3068 最长回文(马拉车)

hdu 3068 最长回文(马拉车)

manacher算法 O(n) 求字符串中最长回文子串 hdu 3068(模板题)

HDU 3068

HDU 3068 最长回文(manacher模板题)

manacher马拉车算法