码迷,mamicode.com
首页 > 其他好文 > 详细

POJ3450 Corporate Identity 【KMP 暴力strstr可过】

时间:2015-02-11 14:45:50      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:poj   kmp   数据结构   算法   c   

题目描述

给你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可过】

标签:poj   kmp   数据结构   算法   c   

原文地址:http://blog.csdn.net/area_52/article/details/43732111

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!