传送门
题意简述:问最长的由两个回文串连接而成最长字串长度。
思路:
正反串各建一个pampampam然后就完了。
代码:
#include<bits/stdc++.h>
#define ri register int
using namespace std;
const int N=1e5+5;
int n,f[N][2],ans=0;
char s[N];
struct pam{
int son[N][26],fail[N],len[N],tot,last,siz[N];
pam(){len[1]=-1,fail[0]=fail[1]=1,tot=1,last=0;}
inline void insert(int x,int id){
int p=last,np,q;
while(s[id-len[p]-1]!=s[id])p=fail[p];
if(!son[p][x]){
len[np=++tot]=len[p]+2,q=fail[p];
while(s[id-len[q]-1]!=s[id])q=fail[q];
fail[np]=son[q][x],son[p][x]=np;
}
last=son[p][x],++siz[son[p][x]];
}
}t1,t2;
int main(){
scanf("%s",s+1),n=strlen(s+1);
for(ri i=1;i<=n;++i)t1.insert(s[i]-'a',i),f[i][0]=t1.len[t1.last];
reverse(s+1,s+n+1);
for(ri i=1;i<=n;++i)t2.insert(s[i]-'a',i),f[n-i+1][1]=t2.len[t2.last];
for(ri i=1;i<n;++i)ans=max(ans,f[i][0]+f[i+1][1]);
cout<<ans;
return 0;
}