题目链接:http://poj.org/problem?id=2752
kmp挺简单的一道题,超时了几次。。。只用找到第一次自身匹配的位置,之后一直利用next数组找失败指针,每个失败指针都是一个前缀,这里想明白了就解决了超时的问题了,本身串就是一个名字,而且是最长的。代码如下:
#include<iostream>
#include<cstdio>
#include<vector>
#include<string.h>
#include<algorithm>
using namespace std;
int nex[400005],len;
char str[400005];
void init_next(int len)
{
int i = 2,j = 0;
while(i <= len)
{
while(j > 0 && str[j+1] != str[i]) j = nex[j];
if(str[i] == str[j+1]) ++j;
nex[i++] = j;
}
}
int main()
{
while(~scanf("%s",str + 1))
{
vector<int> v;
int p = 0;
len = strlen(str + 1);
init_next(len); v.push_back(len);
for(int i = 2,j = 0;i <= len;++i)
{
while(j > 0 && str[i] != str[j+1]) j = nex[j];
if(str[i] == str[j+1]) ++j;
if(i == len && j) {p = j;break;}
}
while(p != 0) {v.push_back(p);p = nex[p];}
for(int i = v.size() - 1;i > -1;--i)
printf("%d ",v[i]);
printf("\n");
memset(str,'\0',sizeof(str));
memset(nex,0,sizeof(nex));
}
return 0;
}
148

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



