标签:
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