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

UVa10340

时间:2014-07-13 20:09:39      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   os   for   io   

All in All

题意:字符串匹配

#include <stdio.h>
#include <string.h>

char S[200000];
char P[200000];
int next[200000];

int KMP(int pos, int len1, int len2)
{
    int i = pos, j = 1, k = 0;
    next[1] = 0;
    while (j < len1)
    if (k == 0 || P[k - 1] == P[j - 1]) j++, k++, next[j] = k;
    else k = next[k];

    j = 1;
    while (i <= len2 && j <= len1)
    {
        if (j == 0 || S[i - 1] == P[j - 1]) i++, j++;
        else j = next[j];
    }
    return j > len1 ? i - len1 : 0;
}

int main(int argc, char *argv[])
{
    int len1, len2, i, t1, t2, j, b, c;

    while(scanf("%s%s", P, S) != EOF)
    {
        t1 = t2 = 1;
        b = -1;
        len1 = strlen(S);
        len2 = strlen(P);

        if(KMP(0, len2, len1) == 0)
            t2 = 0;
        if(t2 == 0)
        {
            for(i = 0; i < len2; i++)
            {
                c = 0;
                for(j = 0; j < len1; j++)
                {
                    if(P[i] == S[j] && b < j)
                    {
                        b = j;
                        c = 1;
                        break;
                    }
                }
                if(c != 1)
                    t1 = 0;
            }
        }

        printf("%s\n", t1 || t2 ? "Yes" : "No");
        memset(S, 0, sizeof(S));
        memset(P, 0, sizeof(P));
        memset(next, 0, sizeof(next));
    }
    return 0;
}

 

 

UVa10340,布布扣,bubuko.com

UVa10340

标签:style   blog   color   os   for   io   

原文地址:http://www.cnblogs.com/Susake/p/3841008.html

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