题意:求前i个字符中重复的个数k(如果可以的话)
分析:完全就是2406,只不过2406是判断全部的
AC代码:
#include<iostream>
#include<string.h>
using namespace std;
char t[1000005];
int next[1000005];
int m;
void get_next(){
next[0]=-1;
int i,j=-1;
for(i=1;i<m;++i){
while(j!=-1&&t[i]!=t[j+1])j=next[j];
if(t[j+1]==t[i])j++;
next[i]=j;
}
}
int main(){
int k=0;
while(cin>>m&&m){
cin>>t;
get_next();
cout<<"Test case #"<<++k<<endl;
for(int i=1;i<m;++i){
// cout<<next[i]<<" "<<i;
// cout<<i-next[i]<<endl;
if(i-next[i]==0)break;
if((i+1)%(i-next[i])==0&&next[i]!=-1)
cout<<i+1<<" "<<(i+1)/(i-next[i])<<endl;
}
cout<<endl;
}
return 0;
}