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;
}
相关推荐
Swift社区14 小时前
LeetCode 465 最优账单平衡
算法·leetcode·职场和发展
聆风吟º14 小时前
【数据结构手札】空间复杂度详解:概念 | 习题
java·数据结构·算法
weixin_4450547214 小时前
力扣热题51
c++·python·算法·leetcode
地平线开发者14 小时前
linux 常见稳定性问题分析方法
算法·自动驾驶
s砚山s15 小时前
代码随想录刷题——二叉树篇(九)
算法
地平线开发者15 小时前
大模型常见量化方法简介
算法·自动驾驶
smj2302_7968265217 小时前
解决leetcode第3801题合并有序列表的最小成本
数据结构·python·算法·leetcode
栗少18 小时前
英语自学手册:系统化进阶指南基于《英语自学手册》的方法论与行动路径
人工智能·算法
Xの哲學18 小时前
深入解析 Linux systemd: 现代初始化系统的设计与实现
linux·服务器·网络·算法·边缘计算
sinat_2554878118 小时前
InputStream/OutputStream小讲堂
java·数据结构·算法