1、B站视频链接:F05 Manacher(马拉车)_哔哩哔哩_bilibili
题目链接:【模板】manacher - 洛谷



#include <bits/stdc++.h>
using namespace std;
const int N=3e7;
char a[N],s[N];
int d[N];//回文半径函数
void get_d(char*s,int n){
	d[1]=1;
	for(int i=2,l,r=1;i<=n;i++){
		if(i<=r)d[i]=min(d[r-i+1],r-i+1);//盒内加速
		while(s[i-d[i]]==s[i+d[i]])d[i]++;//盒外暴力枚举
		if(i+d[i]-1>r)l=i-d[i]+1,r=i+d[i]-1;//更新盒子 
	}
}
int main(){
	//改造串 
	scanf("%s",a+1);
	int n=strlen(a+1),k=0;
	s[0]='$',s[++k]='#';//0为$,1为#
	for(int i=1;i<=n;i++){
		s[++k]=a[i],s[++k]='#';
	}
	n=k;//最后的长度为k
	get_d(s,n);
	int ans=0;
	for(int i=1;i<=n;i++){
		ans=max(ans,d[i]);
	}
	printf("%d\n",ans-1);//最大半径减一 
	return 0;
} 
 




















