最长对称子串(KMP)

对给定的字符串,本题要求你输出最长对称子串的长度。例如,给定"Is PAT&TAP symmetric?",最长对称子串为"s PAT&TAP s",于是你应该输出11。

输入格式:

输入在一行中给出长度不超过1000的非空字符串。

输出格式:

在一行中输出最长对称子串的长度。

输入样例:
Is PAT&TAP symmetric?
输出样例:
11
#include
#include
#include
using namespace std;
#define N 225000
///dp[i] 表示以i点为中心向右最大回文长度
///则答案就是max(dp[i]) -1
int dp[N];
char P[N], T[N];
///在每一个字符间插入# 这样得到的回文串长度一定是奇数(包含#)

int Have_P()
{
    int j, len = strlen(T);
    j = 0;
    P[j++] = '$';
    P[j++] = '#';
    for(int i = 0; i < len; i++)
        P[j++] = T[i], P[j++] = '#';
    P[j] = '\0';
    return j;
}

void KMP(int Plen)
{
    int mx = 0, id = 0;
    dp[0] = 0;
    for(int i = 1; i < Plen; i++)
    {
        dp[i] = mx>i? min(dp[2*id-i], mx-i) : 1;
        while(P[i + dp[i]] == P[i - dp[i]])dp[i]++;
        if(i + dp[i] > mx)
        {
            mx = dp[i] + i;
            id = i;
        }
    }
}

int main()
{
    while(gets(T))
    {
        int len, ans = 0;
        KMP(len = Have_P());
        for(int i = 0; i < len; i++)
            ans = max(ans,dp[i]-1);
        printf("%d\n",ans);
    }
    return 0;
}


你可能感兴趣的:(KMP)