KMP算法 next数组求解详解

next数组的求解方法是:

第0位的next值为-1,第1位的next值为0,后面求解每一位的next值时,根据前一位进行比较。

首先将前一位与其next值对应的内容进行比较,如果相等,则该位的next值就是前一位的next值加上1;如果不等,向前继续寻找next值对应的内容来与前一位进行比较,直到找到某个位上内容的next值对应的内容与前一位相等为止,则这个位对应的值加上1即为需求的next值;如果找到第一位都没有找到与前一位相等的内容,那么需求的位上的next值即为0。

如果数组的下标是从1 开始的 那么Next数组默认第0位和第1位 是0 和 1

举例解释上边一段话的意思
假设求串′ababaaababaa′的next数组

模式串ababaaababaa
下标01234567891011

1、前两位:next数组前两位一定是-1,0 即前两位ab对应的next数组为-1 0,则:

模式串ababaaababaa
下标01234567891011
next数组-10          

2、接下来看第2位,按照next数组求解方法。第2位a的前一位为第1位的b,b的next值为0对应内容为a,b与a不同,向前继续寻找next值对应的内容来与前一位进行比较。因为找到第0位都没有找到与前一位相等的内容,所以第2位a的next值为0,则:

模式串ababaaababaa
下标01234567891011
next数组-100         

3、接下来看第3位b,b的前一位a的next=0对应内容为a,相同,所以该位b的next值就是前一位a的next+1,即为1

模式串ababaaababaa
下标01234567891011
next数组-1001        

4、接下来看第4位a,a的前一位b的next=1对应内容为b,相等,所以该位a的next值就是前一位b的next+1,即为2

模式串ababaaababaa
下标01234567891011
next数组-10012       

5、接下来看第5位a,a的前一位a的next=2对应内容为a,相等,所以该位a的next值就是前一位a的next+1,即为3

模式串ababaaababaa
下标01234567891011
next数组-100123      

6、接下来看第6位a,a的前一位a的next=3对应内容为b,不相等,向前继续寻找next值对应的内容来与前一位进行比较,b的next=1对应的内容为b,依旧不相等,继续向前寻找,第1位b的next=0对应内容为a,相等。因为是在第1位b处实现的相等,所以第6位a的next值为第1位b的next+1,即为1

模式串ababaaababaa
下标01234567891011
next数组-1001231     

7、接下来看第7位,同样道理,得出b的next值为1

模式串ababaaababaa
下标01234567891011
next数组-10012311    

8、接下来看第8位,前一位b的next值1对应内容为b,相等,所以此处next值为2

模式串ababaaababaa
下标01234567891011
next数组-100123112   

9、第9位同理可得,为3

模式串ababaaababaa
下标01234567891011
next数组-1001231123  

10、第10位a的前一位b的next值3对应内容为b,相等,所以此处next值为4

模式串ababaaababaa
下标01234567891011
next数组-10012311234 

11、最后,第11位同理可以得到next值位5

模式串ababaaababaa
下标01234567891011
next数组-100123112345

综上,串′ababaaababaa′的next数组为-1 0 0 1 2 3 1 1 2 3 4 5

如果数组下标是从1开始 next数组从0 开始  结果就是上边的每个+1   0 1 1 2 3 4 2 2 3 4 5 6

  • 9
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
KMP算法中的next数组是用来记录模式串中每个位置之前的最长相同前缀后缀的长度。具体来说,next数组的每个元素next\[i\]表示当模式串的第i+1个字符与文本串不匹配时,模式串应该跳过的位置。\[2\]在KMP算法的实现中,通过使用next数组,可以在匹配过程中避免不必要的回溯,提高匹配效率。 next数组求法有多种方法,其中一种常用的方法是通过动态规划的思想来计算。具体步骤如下: 1. 初始化next数组,将next\[0\]置为-1,next\[1\]置为0。 2. 从模式串的第2个字符开始,依次计算每个位置的next值。 3. 对于位置i,如果模式串的第i个字符与前缀的下一个字符相等,则next\[i\]等于前缀的长度加1。 4. 如果模式串的第i个字符与前缀的下一个字符不相等,则需要根据已知的next值来更新next\[i\]。 - 如果next\[j\]等于-1,或者模式串的第i个字符与前缀的下一个字符相等,则next\[i\]等于j。 - 如果next\[j\]不等于-1,且模式串的第i个字符与前缀的下一个字符不相等,则需要继续向前回溯,即将j更新为next\[j\],然后再进行比较。 - 重复上述步骤,直到找到一个满足条件的j或者回溯到模式串的起始位置。 通过以上步骤,可以得到完整的next数组,用于KMP算法的匹配过程中的跳转操作。\[2\]在KMP算法的代码实现中,可以根据next数组的值来决定模式串的后移位置,从而提高匹配效率。\[3\] #### 引用[.reference_title] - *1* *2* [KMP算法&next数组详解](https://blog.csdn.net/ooblack/article/details/109329361)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [KMP 算法中的 next 数组](https://blog.csdn.net/m0_52423355/article/details/123807325)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值