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

HDU3068 最长回文串

时间:2015-12-19 12:24:50      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:

题目大意:给出一个字符串,求其回文串的长度。有多组数据。

分析:manacher算法模板题。

//在原字符串两边和中间插入一个从未出现的字符,比如‘#’。然后再在最前面插入一个‘*’。
#include<iostream> #include<cstdio> #include<cstring> using namespace std; #define MAXN 230005 char s1[MAXN],s2[MAXN]; int ans,p[MAXN],maxid,len; int main() { while(scanf("%s",s1)!=-1) { ans=0; memset(p,0,sizeof p); memset(s2,0,sizeof s2); len=strlen(s1); s2[0]=*; s2[1]=#; for(int i=0,j=2;i<len;i++) { s2[j++]=s1[i]; s2[j++]=#; } len=strlen(s2); p[0]=1,maxid=0; for(int i=1;i<len;i++) { if(p[maxid]+maxid>i) { p[i]=min(p[2*maxid-i],maxid+p[maxid]-i); } else p[i]=1; for(;i+p[i]<len&&i-p[i]>=0&&s2[i+p[i]]==s2[i-p[i]];p[i]++) if(p[i]+i>p[maxid]+maxid)maxid=i; } for(int i=0;i<len;i++) if(p[i]>ans)ans=p[i]; printf("%d\n",ans-1); } }

 

HDU3068 最长回文串

标签:

原文地址:http://www.cnblogs.com/hefenghhhh/p/5058889.html

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