题目描述
给定一个串,如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。
输入样例1 | 输出样例1 |
6 a ab abc abcd abcda abcdab | empty\n empty\n empty\n empty\n a\n ab |
#include<iostream>
#include<string>
using namespace std;
string matched_prefix_postfix(string p){
int k=-1 , j = 0 ;
int m = p.length()+1;//题眼;避免忽略最后一位
int *next = new int [m];
next[0] = -1;
while(j<m-1){
if(k==-1||p[j]==p[k]){
k++,j++;
next[j] = k;
}
else k = next[k];
}
if(next[m-1]>0){
string final(p,0,next[m-1]);
return final;
}
else return "empty";
}
int main(){
int t;
cin>>t;
string p;
while(t--){
cin>>p;
// cout<<p.length()<<endl;
// cout<<p.length()<<endl;
string str_out=matched_prefix_postfix(p);
cout<<str_out<<endl;
}
return 0;
}