kmp算法

本文深入讲解了KMP算法的核心概念及应用,包括next数组的计算方法及其在模式串匹配问题中的作用,通过实例帮助理解算法流程。

昨天看到网易的笔试题有一道kmp算法,就复习了一遍

kmp算法主要针对的是模式串匹配问题,主要分为两个步骤

一、求解next数组

     所谓的next数组,指的是当主串(在下标i)和模式串(在下标j)上的元素不匹配时,模式串下标j要回退的位置,记为k

每一个j,都对应一个回退的位置k,所以在求模式串的匹配问题时,我们首先要根据模式串初始化一个next数组

    具体求解可参考http://www.cnblogs.com/tangzhengyue/p/4315393.html

   特别注意失配问题,当模式串p[j+1]位置的字符和回退的p[next[j+1]]位置的字符相等时,匹配仍然不成功,需要继续往后回退

即 next[j+1]回退到 next[next[j+1]]位置

二、求解当前的主串是否和模式串匹配

     当主串(在下标i)和模式串(在下标j)上的元素匹配时,主串和模式串都遍历到下一个元素进行匹配,当不匹配时,模式串回退到next[j]位置,当循环遍历完,判断模式串的下标是否到达模式串的尾部。

     详细过程解析可参考http://www.cnblogs.com/yjiyjige/p/3263858.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值