题目描述
给你n个字符串,问其最长的公共串是啥。如果长度都是最长,输出字典序小的。
Sample Input
3
aabbaabb
abbababb
bbbbbabb
2
xyz
abc
0
Sample Output
abb
IDENTITY LOST
解题思路
取第一个字符串O(n^2)遍历,对其他字符串直接strstr匹配即可。 用KMP当然最好。
用ans存放当前的最优解。
下面是代码
#include <cstdio>
#include <cstring>
const int maxn = 210;
int n;
int anslen = 0;
char ans[maxn];
char s[4010][maxn];
char p[maxn];//模式串
int main()
{
while(scanf("%d",&n) && n) {
anslen = 0;
for(int i = 0 ; i < n ; i ++) scanf("%s",s[i]);
/** 遍历s[0] */
int len1 = strlen(s[0]);
for(int i = 0 ; i < len1 ; i ++) {
for(int j = i ; j < len1 ; j ++) {
/** 模式串是s[0][i,i+1,...,j] */
for(int k = i ; k <= j ; k ++) {
p[k-i] = s[0][k];
}
p[j-i+1] = '\0';
/** 模式串已就绪 */
bool flag = true;//记录其他主串是否都有p串
int len = j-i+1;//长度
if(len < anslen) continue;
for(int k = 1 ; k < n ; k ++) {
if(strstr(s[k],p) == NULL) {
flag = false;
break;
}
}
if(flag) {
if(len == anslen) {//看字典序
if(strcmp(p,ans) < 0) {
strcpy(ans,p);
}
}else {
strcpy(ans,p);
anslen = len;
}
}
}
}
if(anslen > 0) printf("%s\n",ans);
else printf("IDENTITY LOST\n");
}
return 0;
}
POJ3450 Corporate Identity 【KMP 暴力strstr可过】
原文地址:http://blog.csdn.net/area_52/article/details/43732111