码迷,mamicode.com
首页 > 其他好文 > 详细

字符串的模板 Manacher

时间:2018-03-06 21:55:50      阅读:172      评论:0      收藏:0      [点我收藏+]

标签:技术分享   const   pen   字符串   man   print   int   span   ring   

 

马拉车算法

技术分享图片
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<algorithm>
 4 #include<cstring>
 5 #include<cmath>
 6 #include<queue>
 7 using namespace std;
 8 const int maxn=100100;
 9 int n,siz;
10 char ch[maxn]={};
11 char ch1[maxn*2]={};
12 int p[maxn*2]={};
13 void fir(){
14     siz=n*2+2;
15     ch1[0]=$;ch1[1]=#;
16     for(int i=1;i<=n;i++)ch1[i*2]=ch[i-1],ch1[i*2+1]=#;
17     ch1[siz]=\0;
18 }
19 int Manacher(){
20     fir();int x=0,j=0,ans=0;
21     for(int i=1;i<siz;i++){
22         if(x+j>i)p[i]=min(x+j-i+1,p[x*2-i]);
23         else p[i]=0;
24         while(ch1[i+p[i]]==ch1[i-p[i]])p[i]++;
25         if(i+p[i]-1>x+j)x=i,j=p[i]-1;
26         if(p[i]>ans)ans=p[i];
27         //cout<<i<<ch1[i]<<p[i]<<endl;
28     }
29     return ans-1;
30 }
31 int main(){
32     int T;scanf("%d",&T);
33     while(T-->0){//ch[i],ch1[i],p[i]似乎都不用清空,因为所有的用之前都已经被清一次了。
34         scanf("%s",ch);n=strlen(ch);
35         int ma=Manacher();
36         printf("%d\n",ma);
37     }
38     return 0;
39 }
Manacher

 

字符串的模板 Manacher

标签:技术分享   const   pen   字符串   man   print   int   span   ring   

原文地址:https://www.cnblogs.com/137shoebills/p/8516404.html

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