POJ 2406 Power Strings

题目大意:问原串是否可以是某个子串周期组成.如果是的话输出周期,否则输出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;
}


 

你可能感兴趣的:(POJ 2406 Power Strings)