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

Simpsons’ Hidden Talents - HDU 2594(求相同的前缀后缀)

时间:2015-08-15 10:12:53      阅读:103      评论:0      收藏:0      [点我收藏+]

标签:

题目大意:给你两个字符串,找出一个最大的子串,这个子串要是前面串的前缀并且是后面串的后缀...........
 
分析:next的简单运用吧,可以把两个串进行合并,中间加一个不能被匹配的字符,然后求出来next就行了.......确实很水
代码如下:
=========================================================================================================
#include<stdio.h>
#include<string.h>

const int MAXN = 1e5+7;
const int oo = 1e9+7;

char a[MAXN], b[MAXN];
int next[MAXN];

void GetNext(char s[], int N)
{
    int i=0, j=-1;
    next[0] = -1;

    while(i < N)
    {
        if(j==-1 || s[i]==s[j])
            next[++i] = ++j;
        else
            j = next[j];
    }
}

int main()
{
    while(scanf("%s%s", a, b) != EOF)
    {
        int N = strlen(a);

        a[N] = *, a[N+1] = 0;
        strcat(a, b);
        N = strlen(a);

        GetNext(a, N);

        if(next[N] == 0)
            printf("0\n");
        else
        {
            a[next[N]] = 0;
            printf("%s %d\n", a, next[N]);
        }
    }

    return 0;
}

 

Simpsons’ Hidden Talents - HDU 2594(求相同的前缀后缀)

标签:

原文地址:http://www.cnblogs.com/liuxin13/p/4731847.html

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