POJ-2406 Power Strings
题解:
其实就是用next把模式串标记出来,然后用如果strlen(模式串)%(strlen(模式串)-next[strlen(模式串)])==0的话,说明这个模式串可以被几个字串组合而成,而个数等于strlen(模式串)/(strlen(模式串)-next[strlen(模式串)])
代码:
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
int next[1000005];
void Next(char T[])
{
int i=0,j=-1,l=strlen(T);
next[0]=-1;
while(i<l)
{
if(j==-1||T[j]==T[i])next[++i]=++j;
else j=next[j];
}
}
int main()
{
char T[1000005];
while(scanf("%s",&T)!=EOF)
{
if(T[0]=='.')break;
int l=strlen(T);
Next(T);
if(l%(l-next[l])==0)printf("%d\n",l/(l-next[l]));
else printf("1\n");
}
return 0;
}
POJ-2406 PowerStrings题解

本文详细解析了POJ-2406 PowerStrings问题的解决思路,利用KMP算法中的next数组判断字符串是否由更短子串重复构成,通过计算模式串的长度与next值的关系,确定重复次数。
235

被折叠的 条评论
为什么被折叠?



