• 【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;
    }
    

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

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

  • 相关阅读:
    java中的成员变量和局部变量
    多线程实现输出当前时间,和猜数字游戏
    JDBC
    jQuery和原生JS的对比
    JavaScript有趣的知识点
    MySQL的数据类型
    行级元素和块级元素
    重定向和请求转发的区别
    JSP九大内置对象
    Python练习
  • 原文地址:https://www.cnblogs.com/MisakaAzusa/p/9218941.html
Copyright © 2020-2023  润新知