题意:求字符串中的最小子串的个数;
思路:n==len(s)字符串长度
0 next[n]-1
R 1 | 2 | 3 | 4 | 5
| | | | |
Y 1 | 2 | 3 | 4 | 5
n-next[n] n-1
由kmp算法:上述R缎和Y缎完全相同,
由上图得若len%(len-next[len])==0
则R1==Y1==R2==Y2==R3...==Y4==R5==Y5
即 若len%(len-next[len])==0
则最小子串长度为n-next[n]
个数为len/(len-next[len])
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=1000005;
int Next[maxn];
char s[maxn];
void getnext(int l)
{
int i=0,j=-1;Next[0]=-1;
while(i<l)
{
if(j==-1||s[i]==s[j])
{
i++;
j++;
Next[i]=j;
}
else j=Next[j];
}
}
int main()
{
int len;
while(scanf("%s",s),strcmp(s,"."))
{
len=strlen(s);
getnext(len);
if(len%(len-Next[len])==0)
printf("%d\n",len/(len-Next[len]));
else printf("1\n");
}
return 0;
}