POJ2406 Power Strings

时间:2020-02-19 19:44:33   收藏:0   阅读:50

假设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\n",len/(len-nxt[len]));
        else printf ("1\n");
    }
    return 0;
}

 

原文:https://www.cnblogs.com/zhanglichen/p/12332706.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!