深圳幻海软件技术有限公司 欢迎您!

kmp算法next求解详解

2023-04-05

文章目录前言一、基本概念二、next数组里的两种情况1.产生两种情况的原因及介绍2.p[j+1]==p[i]时3.p[j+1]!=p[i]时总结前言相信大家在学习kmp算法时,如果会求next了,那么对于kmp算法基本就懂了,可是求解next数组的理解和求解比较困难,那么我今天就来详细的来讲解kmp

文章目录

  • 前言
  • 一、基本概念
  • 二、next数组里的两种情况
    • 1.产生两种情况的原因及介绍
    • 2.p[j + 1] == p[i]时
    • 3.p[j + 1] != p[i]时
  • 总结


前言

相信大家在学习kmp算法时,如果会求next了,那么对于kmp算法基本就懂了,可是求解next数组的理解和求解比较困难,那么我今天就来详细的来讲解kmp算法的next的求解,此文章是建立在你对于kmp算法有一定的了解之后,而对于next的求解比较头疼的基础之上的,如果懂可以去自行了解(我之后可能会出kmp算法得完整详解)

一、基本概念

1️⃣“非平凡前缀”:指除了最后一个字符以外,一个字符串的全部头部组合。
2️⃣“非平凡后缀”:指除了第一个字符以外,一个字符串的全部尾部组合。(后面会有例子,均简称为前/后缀)
3️⃣s[ ]是模式串,即母串。
4️⃣p[ ]是模板串,即需要匹配的字符串

二、next数组里的两种情况

1.产生两种情况的原因及介绍

我们先拿一个典型的代码来做演示

for (int i = 1, j = -1; i < m; i ++ )//i从1开始是因为next第一个永远为-1,j从-1开始是为了后面下标j所在位置的next就是j所在的位置
    {
    ne[0] = -1;
        while (j >= 0 && p[j + 1] != p[i])//j+1也是为了使j的所在位置的next就是j所在的位置
        {
         j = next[j]}
        if (p[j + 1] == p[i]) 
        {
        j ++ ;
        }
        next[i] = j;
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

2.p[j + 1] == p[i]时

3.p[j + 1] != p[i]时

🅿️其实这一步也是一个字符串匹配,只不过是利用了现有的条件,我这里举一个例子,当然例子只是用来帮助理解的
🔹>🔹
🔹
🔹

总结