首页 > 其他 > 详细

马拉车

时间:2020-03-20 18:03:25      阅读:45      评论:0      收藏:0      [点我收藏+]

主要是想得到p数组

对于p[i]有,以i为中心的回文串起始坐标为(i-p[i])/2;长度为 p[i]-1;

#include<iostream>  
#include<string.h>
#include<algorithm>  
using namespace std;

char s[1000];
char s_new[2000];
int p[2000];

int Init()
{
    int len = strlen(s);
    s_new[0] = $;
    s_new[1] = #;
    int j = 2;

    for (int i = 0; i < len; i++)
    {
        s_new[j++] = s[i];
        s_new[j++] = #;
    }

    s_new[j] = \0;    

    return j; 
}

int Manacher()
{
    int len = Init();  //取得新字符串长度并完成向s_new的转换  
    int maxLen = -1;   //最长回文长度  
    int check=0; //最长回文串的起始位置 
    int id;
    int 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 (s_new[i - p[i]] == s_new[i + p[i]])  //不需边界判断,因为左有‘$‘,右有‘\0‘  
            p[i]++;

        //我们每走一步i,都要和mx比较,我们希望mx尽可能的远,这样才能更有机会执行if (i < mx)这句代码,从而提高效率 
        if (mx < i + p[i])  
        {
            id = i;
            mx = i + p[i];
        }
        if(p[i]-1>maxLen){
            maxLen=p[i]-1;
            check=(i-p[i])/2;
        } 
    }
    //输出最长字符串 
 //   for(int i=check;i<check+maxLen;i++){
  //      cout<<s[i];
//    }
//    cout<<endl;

    return maxLen;
}

int main()
{
    while (printf("请输入字符串:\n"))
    {
        scanf("%s", s);
        printf("最长回文长度为 %d\n\n", Manacher());
    }

    return 0;
}

 

马拉车

原文:https://www.cnblogs.com/LH2000/p/12533051.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!