题目大意:问原串是否可以是某个子串周期组成.如果是的话输出周期,否则输出1
思路:
在这道题是HDU1358的弱化版
用next数组判断原串就为前缀是否是周期组成,如果是的话然后再用next数组求出循环节就可以了
只是考虑了前缀为原串的情况,周期至少可以为1,那么就求出next数组直接判断next[n+1]的情况就可以了的. 我以为是在所有前缀中找出最大的.1wa.囧囧.
比如abcabcd,那么这样的情况你只能输出1.
AC Program:
#include <vector>
#include <list>
#include <map>
#include <set>
#include <queue>
#include <deque>
#include <stack>
#include <bitset>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <queue>
#include <cassert>
typedef long long ll;
#define clr(a) memset((a),0,sizeof (a))
#define rep(i,a,b) for(int i=(a);i<(int)(b);i++)
#define per(i,a,b) for(int i=((a)-1);i>=(int)(b);i--)
#define inf (0x7fffffff)
#define eps 1e-6
#define MAXN
#define MODN (1000000007)
using namespace std;
char miao[1000005];
int next[1000005];
int len;
void get_next(){
int k=0;
int j=1;
next[1]=0;
while(j<=len){
if(k==0 || miao[j]==miao[k]){
j++;
k++;
next[j]=k;
}
else{
k=next[k];
}
}
}
int main(){
while(~scanf("%s",miao+1)){
if(miao[1]=='.')break;
len=strlen(miao+1);//加了个1就是得时时注意阿,晕死
get_next();
/*
rep(i,0,len+2)
cout<<next[i]<<" ";
cout<<endl;
*/
int maximum=1;//这直接把原串不是周期的简单的直接输出为1了
if(len%(len-(next[len+1]-1))==0)
maximum=max(maximum,len/(len-(next[len+1]-1)));//注意是next[i+1]-1后才被i减去
cout<<maximum<<endl;
};
//system("pause");
return 0;
}