KMP子串匹配

分为两个操作:

1.求next数组/longestPrefix数组

2.kmp字符串匹配

模板:

cpp 复制代码
#include <iostream>
#include <vector>
#include <string>
using namespace std;

vector<int> computePrefix(string pat) {
    int m = pat.size();
    vector<int> longestPrefix(m);
    for(int i = 1, k = 0; i < m; i ++ ) {
        while(k > 0 && pat[i] != pat[k]) {
            k = longestPrefix[k - 1];
        }   
        if(pat[i] == pat[k]) {
            longestPrefix[i] = ++k;
        } 
        else {
            longestPrefix[i] = k;
        }    
    }
    return longestPrefix;
}

void kmp(string text, string pat) {
    int n = text.size();
    int m = pat.size();
    vector<int> longestPrefix = computePrefix(pat);
       
    for(int i = 0, k = 0; i < n; i ++ ) {
        while(k > 0 && pat[k] != text[i]) {
            k = longestPrefix[k - 1];
        }
        if(pat[k] == text[i]) {
            k ++;
        }
        if(k == m) {
            cout << i - m + 1 + 1 << endl;
            k = longestPrefix[k - 1];
        }
    }
}
int main() {
    string text, pat;
    cin >> text >> pat;

    kmp(text, pat);

    return 0;
}
相关推荐
写代码写到手抽筋1 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.1 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz112 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi83 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
三品吉他手会点灯3 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
乐迪信息3 小时前
乐迪信息:AI算法盒子实时识别船舶烟雾与火焰异常
大数据·人工智能·算法·安全·目标跟踪
J-Tony113 小时前
【JVM】根可达算法
jvm·算法
艾iYYY3 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion4 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode