2016 - 2024

感恩一路有你

next数组通俗求法 KMP算法中的nextval函数值的原理,求详细推导?

浏览量:2916 时间:2021-03-16 18:35:30 作者:admin

KMP算法中的nextval函数值的原理,求详细推导?

1 get Nextval(int*Nextval,const char*string)2{3 int num=strlen(string)4 int i=0,j=-15 Nextval[0]=-16而(i

KMP算法称为KMP算法,因为该算法是由三个人提出的,所以取三个人名字的第一个字母作为算法名称。实际上,KMP算法与BF算法的区别在于,KMP算法巧妙地消除了指针I的回溯问题,只需确定下一个匹配J的位置,将问题的复杂度从O(MN)降低到O(MN)。在KMP算法中,为了在匹配失败时确定J在下一次匹配中的位置,引入了next[]数组。next[J]的值表示P[0]中最长后缀的长度。。。J-1]等于相同字符序列的前缀。next[]数组的定义如下:1)next[J]=-1,J=0.2)next[J]=max(k):0<K<J P[0。。。K-1]=P[J-K,J-1]3)next[J]=0,例如:P a B a J 0.12.34 next-1.001 2,即next[J]=K>0时,表示P[0。。。K-1]=P[J-K,J-1]。因此,KMP算法的思想是:在匹配过程中,如果存在不匹配,如果next[J]>=0,则目标字符串的指针I不变,模式字符串的指针J移到next[J]的位置继续匹配;如果next[J]=-1,则I移到右边,将j设置为0以继续比较。

kmp算法什么意思?

ABABCAC0112312的前两个字母的下一个序列分别是01。直接写第三个“a”时,第一个字母是B,开头字母是a,a!=B,所以是第四个“a”,第一个字母是a,第一个字母是a,第一个字母是a,a=a,所以值是1+1=2(相等时,字符串长度加1),第五个“B”,第一个字母是a,第一个字母是a,第一个字母是a,第一个字母是B,第一个字母是a,AB,第一个字母是AB,AB=AB,所以这个值是2+1=3,第七个字母是“a”,第一个字母是C,它与开头的第一个字母不同等于,所以它是1,第八个字母是“C”,第一个字母是a,它等于开头的第一个字母,所以如果它是2,它将返回逻辑“true”,否则它将返回逻辑“false”。

KMP算法中的next数组如何计算?

下一个数组考虑除当前字符外最长的前缀和后缀。因为除了当前字符外,1前面只有一个字符,所以不可能有公共前缀,所以next(1)是0

next数组通俗求法 kmp算法next计算方法 kmp算法nextval匹配过程

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。