题目
分析
#include <bits/stdc++.h>
using namespace std;
const int N=1e6+7;
int n;
char s[N];
int ne[N];
int main()
{
scanf("%d",&n);
scanf("%s",s+1);
for(int i=2,j=0;i<=n;i++){
while(j!=0&&s[i]!=s[j+1]) j=ne[j];
if(s[i]==s[j+1]) j++;
ne[i]=j;
}
printf("%d\n",n-ne[n]);
return 0;
}