KMP模式匹配算法
2015-10-31 11:21
363 查看
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;2、当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
相关文章推荐
- 对各浏览器的检测
- UIView UILabel UITextField UIButton UIImageView 常用属性
- iOS 8 Auto Layout界面自动布局系列2-使用Xcode的Interface Builder添加布局约束
- KMP模式匹配算法
- google浏览器 加js方法 getSystemTime ctrl+f5刷新多次,自动调用。。
- 背包问题
- 用JAVA开发WEB Service
- myql 数据库连接池
- 用例图练习
- POJ1579——Function Run Fun(记忆化递归)
- Rafy 框架 - 为数据库生成注释
- Backbone系列:Router的学习
- Timus Online Judge 1658 Sum of Digits
- poj1258prim算法
- mil,mm与inch之间的转换
- poj1258prim算法
- sublime text 全局搜索
- 高并发与锁(二)
- 项目视频界面横屏返回竖屏,oncreate执行2次
- linux服务开机启动