hdu_3068_最长回文(Manacher)
2016-05-07 16:44
309 查看
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=3068
题意:给你一个字符串,让你求最长的回文子串。
题解:数据量比较大,暴力O(n2)会超时,直接上马拉车,模版题。
题意:给你一个字符串,让你求最长的回文子串。
题解:数据量比较大,暴力O(n2)会超时,直接上马拉车,模版题。
#include<cstdio> #include<cstring> #define min(a,b) (a)>(b)?(b):(a) #define max(a,b) (a)>(b)?(a):(b) const int maxn = 110005;//字符串长度 struct Manacher{ char str[maxn<<1]; int p[maxn<<1],len,mx,id,tl,ans,i; //bool pre[maxn],suf[maxn];//前(后)缀(前(后)p[i]-1个字符)是回文串 //void init(int len){for(int i=0;i<=len;i++)suf[i]=0,pre[i]=0;} int maxlen(char *s){ len=strlen(s),mx=0,id=0,tl=0,str[tl++]='$',str[tl++]='#'; for(i=0;i<len;i++)str[tl++]=s[i],str[tl++]='#'; for(i=2,str[tl]=0,ans=0;i<tl;i++){ p[i]=mx>i?min(p[(id<<1)-i],mx-i):1; while(str[i-p[i]]==str[i+p[i]])p[i]++; if(i+p[i]>mx)mx=i+p[i],id=i; ans=max(ans,p[i]); //if(i-p[i]==0)pre[p[i]-1]=true; //if(i+p[i]==len*2+2)suf[p[i]-1]=true; } return ans-1; } }M; char s[maxn]; int main(){ while(~scanf("%s",s)){ printf("%d\n",M.maxlen(s)); } return 0; }
相关文章推荐
- 数据结构实验之链表六:有序链表的建立
- 谈C# using的用法与好处
- oracle数据库sql语句
- python 文件读写5个实例
- CSS三列自适应布局
- PAT L1-6. 连续因子 (暴力)
- 【皇甫】☀四套写入方案(仅供参考)
- JobClient
- YJPageView
- Hello World
- c#实现动态加载Dll
- Android高级控件(五)——如何打造一个企业级应用对话列表,以QQ,微信为例
- Android通信—信使的使用实现Activity与Service的通信
- Android高级控件(五)——如何打造一个企业级应用对话列表,以QQ,微信为例
- CSS中background:url(图片) 不能显示的问题
- Codeforces #254 div1 B. DZY Loves FFT 暴力乱搞
- 数据结构--堆的实现之深入分析
- 解析库函数调用与系统调用的区别
- jQuery 基础DOM和CSS操作
- 深入理解Hibernate持久化3种状态