kmp算法next求解详解
创始人
2025-05-29 05:53:45

文章目录

  • 前言
  • 一、基本概念
  • 二、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;}

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

在这里插入图片描述

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

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

总结

相关内容

热门资讯

这3道炒菜谁吃谁知道,鲜香解馋... 在快节奏的现代生活中,一盘热气腾腾、香气扑鼻的炒菜总能瞬间唤醒味蕾,治愈疲惫的身心。今天分享的三道家...
原创 1... 在生活的画卷中,总有那么几笔色彩,让人回味无穷。今天,就让我们用简单的食材,勾勒出松软可口的松饼,让...
土耳其自驾行记(八)地中海边的... 沿土耳其D400海岸公路一路向南,喧嚣渐远,山海愈静。当托罗斯山脉的青黛与地中海的蓝绿相拥,卡什便如...
寻味鹰潭与上清:本地人私藏的小... 寻味鹰潭与上清:本地人私藏的小吃地图与顺路行程全攻略 来鹰潭和上清,如果只看了龙虎山的丹霞风光,却错...
地道的美景美食 这些年的足迹遍布上百座城市,在不断的游走中,愈发深刻地感觉到,真正称得上旅游美景的并非存在于门票闸机...