我的kmp笔记

在str中找ttr第一次出现的位置,没找到就是-1,

bf算法暴力匹配

int BF(char s[], char p[])
{
    int m, n,i,j;
    m = strlen(s);
    n = strlen(p);
    for(i = 0; i < m; i++)
    {
        for(j = 0; j < n; j++)
        {
            if(s[i + j] != p[j])
                break;
            if( j == n - 1)
            {
                return i;
            }
        }
    }
    return -1;
}

kmp算法FJUTACM2149

#include<stdio.h>
#include<string.h>
char s1[1000005],s2[1000005];
int next[1000005];
void get_next(char s[])///求next数组
{
    int i=0,j=-1;
    next[0]=-1;     ///虽然while第一次填next[0]=-1,但是去掉会死循环
    int len=strlen(s);
    while(i<len)
    {
        if(j==-1||s[i]==s[j])
        {
            i++;
            j++;
            ///特例优化 aaaaab 匹配aaaaax时b-x匹配失败,回溯
            if(s[i]!=s[j])
            {
                next[i]=j;
            }
            else
            {
                next[i]=next[j];
            }
        }
        else
        {
            j=next[j];
        }
    }
}
int kmp(char *str,char *ttr)
{
    int i=0,j=0;
    int len1=strlen(str),len2=strlen(ttr);///strlen返回值unsigned放在while会出错
    while(i<len1&&j<len2)
    {
        if(j==-1||str[i]==ttr[j])
        {
            i++;
            j++;
        }
        else
        {
            j=next[j];
        }
    }
    if(j==len2)///succeed
    {
        return i-j;
    }
    else///failed
        return -1;
}
int main()
{
    while(~scanf("%s%s",s1,s2))
    {
        memset(next,0,sizeof(next));
        get_next(s2);
        printf("%d\n",kmp(s1,s2));
    }
    return 0;
}


posted @ 2016-12-30 16:45  Q1143316492  阅读(160)  评论(0编辑  收藏  举报