题目描述
给定一个串,如ABCDAB,则 ABCDAB的真前缀有:{ A, AB,ABC, ABCD, ABCDA } ABCDAB的真后缀有:{ B, AB,DAB, CDAB, BCDAB } 因此,该串的真前缀和真后缀中最长的相等串为AB,我们称之为该串的“最长的真前后缀”。 试实现一个函数string matched_Prefix_Postfix(string str),得到输入串str的最长的真前后缀。若不存在最长的真前后缀则输出empty
输入
第1行:串的个数 n 第2行到第n+1行:n个字符串
输出
n个最长的真前后缀,若不存在最长的真前后缀则输出empty。
样例输入
6 a ab abc abcd abcda abcdab
样例输出
empty empty empty empty a ab
代码
#include <iostream>
#include <string>
using namespace std;
int *get_next(string s)
{
int *n=new int[s.length()];
n[0]=-1;
int i,j;
i=0;
j=-1;
while(i<s.length()-1)
{
if(j==-1 || s[i]==s[j])
{
i++;
j++;
n[i]=j;
}
else
j=n[j];
}
return n;