当前位置: 代码迷 >> 综合 >> 【模板·manacher】 洛谷 P3805 【模板】manacher
  详细解决方案

【模板·manacher】 洛谷 P3805 【模板】manacher

热度:14   发布时间:2023-12-06 07:54:54.0

题目:manacher算法

思路:模板题

代码:

#include<bits/stdc++.h>
using namespace std;#define maxn 22000000char b[maxn+5],a[maxn+5];
int n;
int p[maxn+5];int main() {
    scanf("%s",b);n=strlen(b);for(int i=0;i<n;i++) {
    a[i*2]='#';a[i*2+1]=b[i];}a[n*2]='#';n*=2;n-=1;int id=0,mx=0;p[0]=1;for(int i=1;i<=n;i++) {
    if(i<mx) p[i]=min(p[2*id-i],mx-i);else p[i]=1;while(i-p[i]>=0&&a[i+p[i]]==a[i-p[i]]) p[i]++;if(p[i]+i>mx) {
    mx=p[i]+i;id=i;}}int ans=0;for(int i=1;i<=n;i++) {
    ans=max(ans,p[i]-1);}printf("%d",ans);return 0;
}