#1589 : 回文子串的数量
manager 算法 求得每个字母为中心的回文串的数量 然后 对那个数组统计一下
#include<iostream> #include<math.h> #include<stdio.h> #include<algorithm> #include<string.h> #include<vector> #include<queue> #include<map> typedef long long ll; using namespace std; #define MAXN 800010 #define inf 1000000000 char z[MAXN*2+10],y[MAXN]; int p[MAXN*2+10]; void Mana(int n) { int mx=0; int id=0; for(int i=1;i<n;i++) { if(mx>i) p[i]=min(p[2*id-i],mx-i); else p[i]=1; for(;z[i+p[i]]==z[i-p[i]];p[i]++) ; if(p[i]+i>mx) { mx=p[i]+i; id=i; } } } int main() { scanf("%s",y); int l=1; z[0]='&'; z[l++]='#'; int len=strlen(y); for(int i=0;i<len;i++) { z[l++]=y[i]; z[l++]='#'; } Mana(l); ll ans=0; for(int i=1;i<l;i++) ans=ans+p[i]/2; printf("%lld\n",ans); return 0; }
posted on 2017-10-21 08:22 HelloWorld!--By-MJY 阅读(532) 评论(0) 编辑 收藏 举报