hdu_3068_最长回文(Manacher)
来源:互联网 发布:数据分析师累吗 编辑:程序博客网 时间:2024/05/07 13:13
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=3068
题意:给你一个字符串,让你求最长的回文子串。
题解:数据量比较大,暴力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;}
0 0
- hdu_3068_最长回文(Manacher)
- Manacher:最长回文
- Manacher求最长回文
- 【HDU3068】最长回文【manacher】
- MANACHER最长回文算法
- HDU3068 最长回文 manacher
- MANACHER 最长回文序列
- HDOJ3068 最长回文(Manacher)
- 【HDU3068】最长回文【Manacher】
- 最长回文字符串Manacher
- 最长回文串 manacher
- manacher(最长回文串)
- 最长回文 hdu3068 manacher
- 最长回文串-manacher
- Manacher HDU3068 最长回文
- 最长回文串 Manacher
- HDU3068[最长回文]--Manacher
- HDU 3068(最长回文-manacher)[Template:manacher]
- 委派构造函数
- java中的IO整理
- MyEclipse开发J2EE常见问题
- 数论知识总结
- xml解析-dom4j方式
- hdu_3068_最长回文(Manacher)
- idea中的jsp页面out对象无法调用write
- Remove Duplicates from Sorted Array
- 新浪微博分享MD5签名生成器没反应
- high_memeory 映射---3
- 2016年5月7日所用即所需
- MVVM
- linux平台下防火墙iptables原理
- MWC-xxd新西达电机及电调标定