标签:
| Time Limit: 3000MS | Memory Limit: 65536K | |
| Total Submissions: 35119 | Accepted: 14519 |
Description
Input
Output
Sample Input
abcd aaaa ababab .
Sample Output
1 4 3
Hint
Source
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#include<queue>
#include<vector>
#include<stack>
using namespace std;
char s[1000010];
int next[1000010];
void getnext()
{
next[0]=-1;
for(int i=1,j=-1;s[i];i++)
{
while(j!=-1&&s[j+1]!=s[i]) j=next[j];
if(s[j+1]==s[i]) j++;
next[i]=j;
}
}
int main()
{
while(scanf("%s",s)!=EOF)
{
if(s[0]==‘.‘)
break;
int len=strlen(s);
getnext();
if(len%(len-next[len-1]-1)==0)
printf("%d\n",len/(len-next[len-1]-1));
else
printf("1\n");
}
return 0;
}
标签:
原文地址:http://www.cnblogs.com/a972290869/p/4383841.html