数据结构学习笔记——KMP算法中的常见计算题目总结

简介: 数据结构学习笔记——KMP算法中的常见计算题目总结

例题1


例、求串’abaabc’的next数组值__________。


答:首先设next[1]=0,next[2]=1(要注意这里的数组是从1开始的,而不是0),如下表:

编号 1 2 3 4 5 6
S a b a a b c
next 0 1



当j=3时,k=next[j-1]=next[2]=1,

此时看S[j-1]=S[2]='b’与S[k]=S[1]='a’是否相等,

由于不相等,所以继续向前查找next值对应的字符来与前一位进行比较,由于通过查找至第一位仍未找到相等的字符,直接将其赋值,即next[j]=next[3]=1;

编号 1 2 3 4 5 6
S a b a a b c
next 0 1 1



当j=4时,k=next[j-1]=next[3]=1,

此时看S[j-1]=S[3]='a’与S[k]=S[1]='a’是否相等,

由于相等,即直接next[j]=next[4]=k+1=1+1=2;

编号 1 2 3 4 5 6
S a b a a b c
next 0 1 1 2



当j=5时,k=next[j-1]=next[4]=2,

此时看S[j-1]=S[4]='a’与S[k]=S[2]='b’是否相等,

由于S[k]=S[2]='b’与其不相等,所以继续向前查找next值对应的字符来与前一位进行比较,S[2]对应的next值为1,寻找S[1],找到编号为1的字符,即S[1]=‘a’,

此时比较S[j-1]=S[4]='a’与S[k]=S[1]='a’是否相等,

由于相等,且此时要注意是在第二位S[2]处实现的相等,即

next[j]=next[5]=next[2]+1=1+1=2;

编号 1 2 3 4 5 6
S a b a a b c
next 0 1 1 2 2



当j=6时,k=next[j-1]=next[5]=2,

此时看S[j-1]=S[5]='b’与S[k]=S[2]='b’是否相等,

由于相等,即直接next[j]=next[6]=k+1=2+1=3;

编号 1 2 3 4 5 6
S a b a a b c
next 0 1 1 2 2 3


故串’abaabc’的next数组值为011223。


例题2


例、串’ababaaababaa’的next数组值为__________,其next数组为__________。


答:首先设next[1]=0,next[2]=1(要注意这里的数组是从1开始的,而不是0),如下表:

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1



当j=3时,k=next[j-1]=next[2]=1,

此时看S[j-1]=S[2]='b’与S[k]=S[1]='a’是否相等,

由于不相等,所以继续向前查找next值对应的字符来与前一位进行比较,由于通过查找至第一位仍未找到相等的字符,直接将其赋值,即next[j]=next[3]=1;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1


当j=4时,k=next[j-1]=next[3]=1,

此时看S[j-1]=S[3]='a’与S[k]=S[1]='a’是否相等,

由于相等,即直接next[j]=next[4]=k+1=1+1=2;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2



当j=5时,k=next[j-1]=next[4]=2,

此时看S[j-1]=S[4]='b’与S[k]=S[2]='b’是否相等,

由于相等,即直接next[j]=next[5]=k+1=2+1=3;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3



当j=6时,k=next[j-1]=next[5]=3,

此时看S[j-1]=S[5]='a’与S[k]=S[3]='a’是否相等,

由于相等,即直接next[j]=next[6]=k+1=3+1=4;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4


 

当j=7时,k=next[j-1]=next[6]=4,

此时看S[j-1]=S[6]='a’与S[k]=S[4]='b’是否相等,

由于S[k]=S[4]='b’与其不相等,所以继续向前查找next值对应的字符来与前一位进行比较,S[4]对应的next值为2,寻找S[2],找到编号为2的字符,即S[2]=‘b’,

此时比较S[j-1]=S[6]='a’与S[k]=S[2]='b’是否相等,

发现依旧不相等,继续查找,S[2]对应的next值为1,寻找S[1],找到编号为1的字符,即S[1]=‘a’,

此时比较S[j-1]=S[6]='a’与S[k]=S[1]='a’是否相等,

由于相等,且此时要注意是在第二位S[2]处实现的相等,即

next[j]=next[7]=next[2]+1=1+1=2;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2



当j=8时,k=next[j-1]=next[7]=2,

此时看S[j-1]=S[7]='a’与S[k]=S[2]='b’是否相等,

由于S[k]=S[2]='b’与其不相等,所以继续向前查找next值对应的字符来与前一位进行比较,S[2]对应的next值为1,寻找S[1],找到编号为1的字符,即S[1]=‘a’,

此时比较S[j-1]=S[7]='a’与S[k]=S[1]='a’是否相等,

由于相等,且此时要注意是在第二位S[2]处实现的相等,即

next[j]=next[8]=next[2]+1=1+1=2;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2



当j=9时,k=next[j-1]=next[8]=2,

此时看S[j-1]=S[8]='b’与S[k]=S[2]='b’是否相等,

由于相等,即直接next[j]=next[9]=k+1=2+1=3;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3



当j=10时,k=next[j-1]=next[9]=3,

此时看S[j-1]=S[9]='a’与S[k]=S[3]='a’是否相等,

由于相等,即直接next[j]=next[10]=k+1=3+1=4;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4



当j=11时,k=next[j-1]=next[10]=4,

此时看S[j-1]=S[10]='b’与S[k]=S[4]='b’是否相等,

由于相等,即直接next[j]=next[11]=k+1=4+1=5;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5


当j=12时,k=next[j-1]=next[11]=5,

此时看S[j-1]=S[11]='a’与S[k]=S[4]='b’是否相等,

由于相等,即直接next[j]=next[12]=k+1=5+1=6;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6


故串’ababaaababaa’的next数组值为011234223456。


将next数组值整体左移一位,低位用-1填充,如下:

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next -1 0 0 1 2 3 1 1 2 3 4 5


故串’ababaaababaa’的next数组为-1,0,0,1,2,3,1,1,2,3,4,5。


例题3


例、已知字符串S=‘aabaabaabaac’,模式串P=‘aabaac’,求P的next数组值以及具体的KMP算法匹配过程。


答:首先设next[1]=0,next[2]=1(这里设数组是从1开始的,而不是0),如下表:

编号 1 2 3 4 5 6
S a a b a a c
next 0 1



当j=3时,k=next[j-1]=next[2]=1,

此时看S[j-1]=S[2]='a’与S[k]=S[1]='a’是否相等,

由于相等,即直接next[j]=next[3]=k+1=1+1=2;

编号 1 2 3 4 5 6
S a a b a a c
next 0 1 2



当j=4时,k=next[j-1]=next[3]=2,

此时看S[j-1]=S[3]='b’与S[k]=S[2]='a’是否相等,

由于S[k]=S[2]='a’与其不相等,所以继续向前查找next值对应的字符来与前一位进行比较,S[2]对应的next值为1,寻找S[1],找到编号为1的字符,即S[1]=‘a’,

此时比较S[j-1]=S[3]='b’与S[k]=S[1]='a’是否相等,

由于不相等,所以继续向前查找next值对应的字符来与前一位进行比较,由于通过查找至第一位仍未找到相等的字符,直接将其赋值,即next[j]=next[4]=1;

编号 1 2 3 4 5 6
S a a b a a c
next 0 1 2 1



当j=5时,k=next[j-1]=next[4]=1,

此时看S[j-1]=S[4]='a’与S[k]=S[1]='a’是否相等,

由于相等,即直接next[j]=next[5]=k+1=1+1=2;

编号 1 2 3 4 5 6
S a a b a a c
next 0 1 2 1 2


当j=6时,k=next[j-1]=next[5]=2,

此时看S[j-1]=S[5]='a’与S[k]=S[2]='a’是否相等,

由于相等,即直接next[j]=next[6]=k+1=2+1=3;

编号 1 2 3 4 5 6
S a a b a a c
next 0 1 2 1 2 3


可知当主串与模式串进行匹配时,当i=6,j=6时,发生失配,通过next数组值表,可知,next[6]=3,即此时主串当前位置与模式串的第三个字符进行比较,如下:

1667280692109.jpg

然后,发现当i=9,j=6时,又发生失配,如下:

1667280706465.jpg

最后匹配成功。


例题4


例、串’ababaaababaa’的nextval数组为___________。


答:可知next数组为:

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6


即串’ababaaababaa’的next数组值为011234223456,求nextval数组从0开始,且串的位序由1开始,

首先令nextval[1]=next[1]=0;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0



从j=2开始进行求nextval数组,判断pj是否等于p(next[j]),若是则将nextval[j]替换为nextval[next[j]],若不是则nextval[j]=next[j]。


j=2时,p2=b,p(next[2])=p1=a,此时两者不相等,

nextval[2]=next[2]=1;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1



j=3时,p3=a,p(next[3])=p1=a,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[3]=nextval[next[3]]=nextval[1]=0;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0


j=4时,p4=b,p(next[4])=p2=b,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[4]=nextval[next[4]]=nextval[2]=1;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1



j=5时,p5=a,p(next[5])=p3=a,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[5]=nextval[next[5]]=nextval[3]=0;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0


j=6时,p6=a,p(next[6])=p4=b,此时两者不相等,

nextval[6]=next[6]=4;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0 4



j=7时,p7=a,p(next[7])=p2=b,此时两者不相等,

nextval[7]=next[7]=2;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0 4 2



j=8时,p8=b,p(next[8])=p2=b,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[8]=nextval[next[8]]=nextval[2]=1;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0 4 2 1



j=9时,p9=a,p(next[9])=p3=a,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[9]=nextval[next[9]]=nextval[3]=0;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0 4 2 1 0


j=10时,p10=b,p(next[10])=p4=b,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[10]=nextval[next[10]]=nextval[4]=1;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0 4 2 1 0 1


j=11时,p11=a,p(next[11])=p5=a,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[11]=nextval[next[11]]=nextval[5]=0;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0 4 2 1 0 1 0



j=12时,p12=a,p(next[12])=p6=a,此时两者相等,

将nextval[j]替换为nextval[next[j]],即nextval[12]=nextval[next[12]]=nextval[6]=4;

编号 1 2 3 4 5 6 7 8 9 10 11 12
S a b a b a a a b a b a a
next 0 1 1 2 3 4 2 2 3 4 5 6
nextval 0 1 0 1 0 4 2 1 0 1 0 4


可得,故串’ababaaababaa’的nextval数组为0,1,0,1,0,4,2,1,0,1,0,4。


相关文章
|
2月前
|
算法 数据处理 C语言
C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合
本文深入解析了C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合,旨在帮助读者掌握这一高效的数据处理方法。
51 1
|
2月前
|
机器学习/深度学习 算法 数据挖掘
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构。本文介绍了K-means算法的基本原理,包括初始化、数据点分配与簇中心更新等步骤,以及如何在Python中实现该算法,最后讨论了其优缺点及应用场景。
133 4
|
13天前
|
存储 运维 监控
探索局域网电脑监控软件:Python算法与数据结构的巧妙结合
在数字化时代,局域网电脑监控软件成为企业管理和IT运维的重要工具,确保数据安全和网络稳定。本文探讨其背后的关键技术——Python中的算法与数据结构,如字典用于高效存储设备信息,以及数据收集、异常检测和聚合算法提升监控效率。通过Python代码示例,展示了如何实现基本监控功能,帮助读者理解其工作原理并激发技术兴趣。
50 20
|
2月前
|
存储 算法 搜索推荐
Python 中数据结构和算法的关系
数据结构是算法的载体,算法是对数据结构的操作和运用。它们共同构成了计算机程序的核心,对于提高程序的质量和性能具有至关重要的作用
|
2月前
|
数据采集 存储 算法
Python 中的数据结构和算法优化策略
Python中的数据结构和算法如何进行优化?
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
65 1
|
2月前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
243 9
|
2月前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
40 1
|
2月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
72 5
|
2月前
|
存储 算法 Java
数据结构的栈
栈作为一种简单而高效的数据结构,在计算机科学和软件开发中有着广泛的应用。通过合理地使用栈,可以有效地解决许多与数据存储和操作相关的问题。