欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    KMP算法(原创).ppt

    • 资源ID:34297263       资源大小:209KB        全文页数:16页
    • 资源格式: PPT        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    KMP算法(原创).ppt

    简单算法(Brute-Force算法算法)n算法描述:n从正文s和模式p的第一个字符出发,将s和p的字符依次逐个进行比较,如果p中的所有字符均与s中的对应字符匹配,则说明匹配成功;如果在比较过程中发现了一个字符不匹配,则将模式p沿正文s向后移动一个字符的位置,然后再从p的第一个字符开始与中的对应字符逐个进行比较。以此类推,直到匹配成功或到达的末段为止。(2) Brute-Force(2) Brute-Force算法的实现算法的实现 int String:Find Substr(const String& t, int start)constint i = start, j = 0, v;while(i size & j = t.size-1) v = i-t.size+1;else v = -1;return v; 模式匹配的KMP算法n基本思想:n当模式p与正文s进行比较的过程中发现不匹配时,找到一种模式p沿正文s向后移动的规则,以便使得正文s中失去匹配的字符以前的字符不再参与比较,即只从当前失去匹配的字符开始与模式p中的字符继续依次进行比较,并且又不错过模式被发现的机会。n示例:算法分析n假设正文为s0s1sn-1,模式为p0p1pm-1,要实现改进算法,也就是要解决下述问题:当匹配过程中产生失配时(即si != pj),模式“向右滑动”可行的距离有多远,换句话说,当正文中第i个字符与模式中第j个字符“失配”时,正文中第i个字符应与模式中哪个字符相比较?n假设此时应与模式中第k个字符继续比较,其中k应具有以下两个性质:n1、kj,因为当失配时必然使模式p向后移,从而导致kj。移的幅度越小,k与j相差越小。n2、k应取所有可能值可能值中的最大值,因为取最大值就意味着移的幅度最小,也就避免错过成功匹配的机会。n根据这个假设,必然使得下式成立:np0p1pk-1=si-ksi-k+1si-1 (1)n而已经得到的“部分匹配”的结果是:npj-kpj-k+1pj-1=si-ksi-k+1si-1n (2)n(2)式的由来是:n 当初正文中的第i个字符与模式中的第j个字符失配时,说明两者之前的j个字符肯定是一样的,而kj,所以前k个字符也是相同的。这就得出(2)式。n由(1)(2)两式便可得:np0p1pk-1= pj-kpj-k+1pj-1 (3)n(3)式的结论可如下描述:n在模式p中,前k个字符与第j个字符之前的k个字符相同。n设nextj表示:当模式中第j个字符与正文中相应字符“失配”时,在模式中重新和正文中该字符进行比较的字符的位置。n并令nextj=k。nNext数组的完整定义如下:Max k | 0kk满足上式,那么n nextj+1=k+1 式式1n也就是:nextj+1=nextj+1n2、若pk!=pj,则表明p0p1pk ! = pj-kpj-k+1pjn这时如何求nextj+1呢?有两种可能情况转化法n式式1的结论结论可这样描述:何时的k使得pk=pj,就用此时的k代入式1。n而现在的k是pk!=pj,因此必须要换成另外一个“k”,并设它为k2,以使得pk2=pj。n问题又出来了: k2如何得来?n如图:要使得k转为k2,实际上就是将p往右移,移动后p的j对应p的k2。00jjj-k+1kPPnk k2 2,到底是多少首先取决于另一个前提条件前提条件:np0p1pk2-1= pj-k2pj-k2+1pj-1n如图:n实际上,n k2=nextk000jjjj-k+1kkk2k- k2 +1p1p2p3 那么,满足了这个前提条件,是否就满足pk2=pj了呢? 显然两者互不相干。也就是说,仅移动一次不一定满足pk2=pj 。 如果移动一次后得到k2仍然不满足pk2=pj ,就要按照前提条件再移动一次。 依次类推,直到pkn=pj ,或kn=0为止。 此时有: nextj+1= kn +1 而 kn = nextkn-1 k1 =k= nextjn由于, kn kn-1 k1 =kj n因此,当需要求nextj+1时, nextj、 nextk1、 nextk2 nextkn都已经求出来了。

    注意事项

    本文(KMP算法(原创).ppt)为本站会员(豆****)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开