KMP模式匹配算法

相信很多人对于这个还有点不了解,或者说是不懂,下面,通过一道题,来解决软考中的这个问题!

正题:

aaabaaa,其next函数值为多少?

对于这个问题,我们应该怎么做呢?

1、整理:

p1=a,

p2=a,

p3=a,

p4=b,

p5=a,

p6=a,

p7=a

2、计算:

1、当j=1的时候,由上面公式可以得到,next(1)=0;

、当j=2的时候,计算1<k<j,因为j=2,所以1<k<2,在这种情况下,k是不存在的,所以属于其他情况,      所以,next(2)=1;其实说个更加简单的就是,无论什么情况,next(1)=0;next(2)=1;

3、当j=3的时候,计算1<k<j,所以,k=2。然后根据右边式子来判断符合不符合。当k=2,左边是p1,右      边是p2,所以‘p1’=‘p2’,有1我们知道,p1=a,p2=a,所以满足条件,所以k=2,所以              next(3)=2;

4、当j=4的时候,计算1<k<j,所以,k可以为2,也可以为3。当k=2时,判定左边为p1,右边为p3,a=a,所    以,k=2满足条件;当k=3时,左边为p1p2,右边为p2p3,也满足条件,所以根据max(2,3)得,        next(4)=3;

5、当j=5,计算得,k=2、3、4,然后当k=2时,判定左边式子为p1,右边式子为p4,不满足;当k=3时,判    定左边式子为p1p2,右边式子为p3p4,不满足;当k=4时,判定左边式子为:p1p2p3,右边式子为:      p2p3p4,不满足;所以,这种情况属于其他情况,所以next(5)=1;

6、当j=6,计算得到k=2、3、4、5。当k=2时,判定左边式子为:p1,右边式子为:p5,满足条件;当k=3    时,判定左边式子为p1p2,右边式子为p4p5,不满足;当p=4、5时,依次向上判定,皆为不满足。所      以next(6)=2;

7、当j=7,计算得到k=2、3、4、5、6.以此判定每个k值,得到,当k=2,k=3时满足条件,所以根据max函    数,得到next(7)=3;

3、结果:

对上面的next函数值进行汇总,得到,aaabaaa的next函数值为0123123.

4、总结:

其实很简单,也不麻烦,如果自己做得多了,找到了核心算法思想,直接数就可以了,so easy!

如果大家有兴趣,可以做一下eefegefee,结果是0121212123

KMP模式匹配算法的更多相关文章

  1. 线性表-串:KMP模式匹配算法

    一.简单模式匹配算法(略,逐字符比较即可) 二.KMP模式匹配算法 next数组:j为字符序号,从1开始. (1)当j=1时,next=0: (2)当存在前缀=后缀情况,next=相同字符数+1: ( ...

  2. C++编程练习(7)----“KMP模式匹配算法“字符串匹配

    子串在主串中的定位操作通常称做串的模式匹配. KMP模式匹配算法实现: /* Index_KMP.h头文件 */ #include<string> #include<sstream& ...

  3. 详细解读KMP模式匹配算法

    转载请注明出处:http://blog.csdn.net/fightlei/article/details/52712461 首先我们需要了解什么是模式匹配? 子串定位运算又称为模式匹配(Patter ...

  4. [从今天开始修炼数据结构]串、KMP模式匹配算法

    [从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...

  5. 字符串的模式匹配算法——KMP模式匹配算法

    朴素的模式匹配算法(C++) 朴素的模式匹配算法,暴力,容易理解 #include<iostream> using namespace std; int main() { string m ...

  6. 串、KMP模式匹配算法

    串是由0个或者多个字符组成的有限序列,又名叫字符串. 串的比较: 串的比较是通过组成串的字符之间的编码来进行的,而字符的编码指的是字符在对应字符集中的序号. 计算机中常用的ASCII编码,由8位二进制 ...

  7. 数据结构(三)串---KMP模式匹配算法

    (一)定义 由于BF模式匹配算法的低效(有太多不必要的回溯和匹配),于是某三个前辈发表了一个模式匹配算法,可以大大避免重复遍历的情况,称之为克努特-莫里斯-普拉特算法,简称KMP算法 (二)KMP算法 ...

  8. 浅谈KMP模式匹配算法

    普通的模式匹配算法(BF算法) 子串的定位操作通常称为模式匹配算法 假设有一个需求,需要我们从串"a b a b c a b c a c b a b"中,寻找内容为"a ...

  9. 初探—KMP模式匹配算法

    KMP算法思想: 普通的字符串匹配算法S主串必须要回溯.但回溯就影响了效率. 改进的地方也就是这里,我们从P 串本身出发,事先就找准了T自身前后部分匹配的位置,那就可以改进算法. next数组的含义: ...

随机推荐

  1. Delphi cxGrid –--> RecordIndex out of Range

    delphi 导出数据时常常出现这样一个错误 < RecordIndex out of Range > 处理办法: 设定 cxGridDBTableView 的 GridModeBuffe ...

  2. 6.SpringMVC注解启用

    SpringMVC注解可以帮助我们快速地注入 属性和参数 提高开发效率. 由于 有相当一部分人讨厌xml配置方式 注解可以覆盖 xml则不能 使用注解比xml规范化,因为很多注解都是java的规范的范 ...

  3. GNOME启动时激活NumLock(小键盘数字锁定)

    首先下载numlockx官方源提供的安装包,解压后进入目录运行终端,切换到root账户执行以下命令: python ./setup.py 然后依次点击GNOME菜单项上的“系统->首选项-> ...

  4. java 入门 第二季3

    1.继承 1.java是单继承的,一个子类只有一个父类 父类,基类 子类,派生类 2.继承的好处:子类拥有父类的所有属性和方法,属性的修饰符不能是private 3.语法规则: class 子类 ex ...

  5. 用原生DOM 遍历页面节点

    代码丢失,直接上图:

  6. zookeeper windows 入门安装和测试

    一.序言       以下是我对zookeeper 的一些理解:       zookeeper 作为一个服务注册信息存储的管理工具,好吧,这样说得很抽象,我们举个“栗子”. 栗子1号: 假设我是一家 ...

  7. POJ 3185 The Water Bowls (高斯消元)

    题目链接 题意:翻译过来就是20个0或1的开关,每次可以改变相邻三个的状态,问最小改变多少次使得所有开关都置为0,题目保证此题有解. 题解:因为一定有解,所以我们可以正序逆序遍历两次求出较小值即可.当 ...

  8. Java version 32转64位

    本来在cmd中 输入 java -version后显示 为 32位,现在需要转为64 位因为eclipse 不兼容,方法: ()下载 java 1.8 64位,安装,然后 ()进入环境变量 发现有两个 ...

  9. Android Service 与 Thread 的区别

    Ref:http://blog.csdn.net/jiangwei0910410003/article/details/17008687 1). Thread:Thread 是程序执行的最小单元,它是 ...

  10. Loadrunner之API测试

    //API函数 web_submit_data web_custom_request   //支持https请求 web_set_sockets_option("SSL_VERSION&qu ...