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

KMP模板

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

标签:字符串   next   ext   ++   details   cin   ||   blog   ios   

今天又加深的理解了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模板

标签:字符串   next   ext   ++   details   cin   ||   blog   ios   

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

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