题意:
给两个字符串,求第一串的前缀与第二串的后缀匹配的最长序列以及长度。
题解:
让两个字符串合并在一起,算出next数组然后取两者中最小的子串就可以了。但是这里我有一个疑问,为什么我用for接上去的字符串会WA,用strcat反倒出现错误了呢?百思不得其解。
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
const int MAXN=50000+7;
char s[MAXN<<1];
char s2[MAXN];
int Next[MAXN<<1];
void getNext()
{
Next[0]=-1;
int j=0,k=-1;
int slen=strlen(s);
while(j<slen)
{
if(k==-1||s[k]==s[j])
{
j++;
k++;
Next[j]=k;
}
else
k=Next[k];
}
}
int main()
{
while(~scanf("%s%s",s,s2))
{
int len1=strlen(s),len2=strlen(s2);
strcat(s,s2);
getNext();
int slen=strlen(s);
int ans=Next[slen];
while(ans>len1||ans>len2) ans=Next[ans];
if(ans==0)
printf("0\n");
else{
for(int i=0;i<ans;i++)
printf("%c",s[i]);
printf(" %d\n",ans);
}
}
}