Time Limit: 3000MS | Memory Limit: 65536K | |
Total Submissions: 51621 | Accepted: 21527 |
Description
Input
Output
Sample Input
abcd aaaa ababab .
Sample Output
1 4 3
Hint
Source
#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
const int N=1000005;
int next[N];
char s[N];
void get_next(int next[],char s[],int len)
{
int i=0;
int j=-1;
next[i]=-1;
while(i<len)
{
if(j==-1||s[i]==s[j])
next[++i]=++j;
else
j=next[j];
}
}
int main()
{
while(~scanf("%s",s))
{
if(s[0]=='.')
break;
int len=strlen(s);
get_next(next,s,len);
if(len%(len-next[len])==0)
printf("%d\n",len/(len-next[len]));
else
printf("1\n");
}
return 0;
}
Time Limit: 3000MS | Memory Limit: 30000K | |
Total Submissions: 18699 | Accepted: 9091 |
Description
Input
number zero on it.
Output
Sample Input
3 aaa 12 aabaabaabaab 0
Sample Output
Test case #1 2 2 3 3 Test case #2 2 2 6 2 9 3 12 4
Source
#include <iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
const int N=1000000+5;
char s[N];
int next[N];
void get_next(int next[],char s[],int len)
{
int i=0,j=-1;
next[0]=-1;
while(i<len)
{
if(j==-1||s[i]==s[j])
next[++i]=++j;
else
j=next[j];
}
}
int main()
{
int len;
int ans=1;
while(~scanf("%d",&len)&&len)
{
scanf("%s",s);
get_next(next,s,len);
printf("Test case #%d\n",ans++);
for(int i=2;i<=len;i++)
if(next[i]>0&&i%(i-next[i])==0)
printf("%d %d\n",i,i/(i-next[i]));
puts("");
}
return 0;
}