• 【luogu P3375 KMP字符串匹配】 模板


    题目链接:https://www.luogu.org/problemnew/show/P3375
    精华:在每次失配后不从头匹配而是尝试找一个新的开始并且是新开始的位置最长的相同前缀和后缀。
    实际上KMP是一种自己匹配自己的模式。好好理解qaq

    #include <cstdio>
    #include <cstring>
    #include <iostream>
    #include <algorithm>
    using namespace std;
    const int maxn = 1000001;
    char a[maxn], b[maxn];
    int next[maxn], lena, lenb;
    int main()
    {
        cin>>a>>b;
        next[0] = -1;
        next[1] = 0;
        int lenb = strlen(b); int lena = strlen(a);
        int j = 0;
        for(int i = 1; i < lenb; i++)
        {
            while(j>0 && b[j] != b[i]) j = next[j];
            if(b[j] == b[i]) ++j;
            next[i+1] = j;
        }//对next失配数组的预处理,其实也是一个自己匹配自己的过程
        j = 0;
        for(int i = 0; i < lena; i++)
        {
            while(j>0 && b[j] != a[i]) j = next[j];//不能继续匹配且j还没减小到0,减小j的值并希望减小的尽量少。
            if(b[j] == a[i]) ++j;//能继续匹配,j++
            if(j == lenb)//找到一处匹配
            {
                printf("%d
    ",i-lenb+2);
                j = next[j];//可重叠的多个匹配返回j = next[j],不可重叠的多个匹配返回j = 0
            }
        }
        for(int i = 1; i <= lenb; i++)
        printf("%d ",next[i]);
        return 0;
    }
    

    隐约雷鸣,阴霾天空,但盼风雨来,能留你在此。

    隐约雷鸣,阴霾天空,即使天无雨,我亦留此地。

  • 相关阅读:
    python获取DBLP数据集
    GNUPLOT 画多组柱状图 以及 折线图 以及各种问题的解决方案
    Leetcode 1:two sum
    测试面试之如何测试一个杯子
    C++小总结
    统计‘1’的个数
    C语言小总结
    剑指offer面试题1---赋值运算符函数
    黑盒测试与白盒测试
    软件测试的原则
  • 原文地址:https://www.cnblogs.com/MisakaAzusa/p/9218941.html
Copyright © 2020-2023  润新知