POJ2406 Power Strings

Posted zhanglichen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了POJ2406 Power Strings相关的知识,希望对你有一定的参考价值。

假设s可以由t重复k次拼成,即s=tttt……tt,我们称为s=t^k。先给定一个字符串s,求最大的n使得存在t满足s=t^n。

用kmp的nxt数组解决~

#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
const int maxn=1e7+14;
char str[maxn];
int nxt[maxn];
int len;
void getNext () {
    int j,k;
    j=0;
    k=-1;
    nxt[0]=-1;
    while (j<len) {
        if (k==-1||str[j]==str[k]) nxt[++j]=++k;
        else k=nxt[k];
    }
}
int main () {
    while (~scanf("%s",str)) {
        if (strcmp(str,".")==0) break;
        len=strlen(str);
        getNext();
        if (len%(len-nxt[len])==0&&len/(len-nxt[len])>1) 
        printf ("%d
",len/(len-nxt[len]));
        else printf ("1
");
    }
    return 0;
}

 

以上是关于POJ2406 Power Strings的主要内容,如果未能解决你的问题,请参考以下文章

POJ 2406 Power Strings

poj2406Power Strings

poj 2406 Power Strings

POJ - 2406 Power Strings

POJ——T 2406 Power Strings

poj 2406 Power Strings