首页 > 其他 > 详细

KMP模板

时间:2018-05-19 00:00:38      阅读:236      评论:0      收藏:0      [点我收藏+]

今天又加深的理解了KMP

认真看了这篇博客,感觉讲的还ok;

然后带着理解写了洛谷的P3375字符串KMP模板题;

#include <iostream>
#include <cstdio>
using namespace std;

const int maxn = 1e6+9;
string t,s;
int Next[maxn];

void get_next()
{
    int len = s.length();
    int k=-1 , j = 0;
    Next[0] = -1;
    while(j<len)
    {
        if(k==-1||s[j]==s[k])
        {
            j++,k++;
            // if(s[j]!=s[k])
            Next[j] = k;
            // else Next[j] = Next[k];
        }
        else k = Next[k];
    }
}

void match()
{
    int slen = s.length();
    int tlen = t.length();
    int j = 0,k = 0;
    while(j<tlen)    
    {
        if(k==-1||s[k]==t[j])
        {
            j++,k++;    
        }
        else k = Next[k];
        if(k==slen)
        {
            printf("%d\n",j-k+1);
            k = 0;j--;
        }
    }
}
int main(){
    cin>>t>>s;
    get_next();
    match();
    // cout<<"))"<<endl;
    int llen = s.length();
    // Next[0] = 0;
    for(int i=1;i<=llen;i++)
        printf("%d%c",Next[i]," \n"[i==llen]);
    return 0;
}

 

KMP模板

原文:https://www.cnblogs.com/ckxkexing/p/9058435.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!