Agony


私信TA

用户名:dzc21

访问量:53266

签 名:

CSDN博客:http://blog.csdn.net/qq_38712932

等  级
排  名 81
经  验 9204
参赛次数 0
文章发表 81
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

CSDN博客:http://blog.csdn.net/qq_38712932 个人博客:http://www.eternallyc.top/blog/index

解题思路:





注意事项:





参考代码:

#include <cstdio>

#include <cstring>

char s1[1000005],s2[10005];

int next[10005];

int lens1,lens2;

void getnext()

{

    int i=0,j=-1;

    next[0]=-1;

    while(i<lens2)

    {

        if(j==-1||s2[i]==s2[j])

        {

            i++;

            j++;

            next[i]=j;

        }

        else

            j=next[j];

    }

}

int KMP()

{

    getnext();

    int i=0,j=0;

    while(i<lens1)

    {

        if(j==-1||s1[i]==s2[j])

        {

            i++;

            j++;

        }

        else

            j=next[j];

        if(j==lens2)

        {

            return i-lens2+1;

        }

    }

    return 0;

}

int main()

{


    while(scanf("%s %s",s1,s2)!=EOF)

    {

        getchar();

        lens1=strlen(s1);

        lens2=strlen(s2);

        printf("%d\n",KMP());

    }

    return 0;

}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答

代码解释器

  评论区