KMP字符串匹配算法

# -*- coding: utf-8 -*-
"""
Created on 2020-04-02 16:01:54

简介:KMP字符串匹配

@author: 杨h  yh4241@foxmail.com 
"""

def gen_pnext(substr):
    m = len(substr)
    pnext = [0]*m
    j = 0
    i = 1
    while i < m:
        if substr[j] == substr[i]:
            pnext[i] = j+1
            j += 1
            i += 1
        elif j != 0:
            j = pnext[j-1]
        else:
            pnext[i] = 0
            i += 1
    return pnext

gen_pnext('abcabgac')
# [out]:[0, 0, 0, 1, 2, 0, 1, 0]
def KMP_algh(string, substring):
    pnext = gen_pnext(substring)
    i, j = 0, 0
    n = len(string)
    m = len(substring)
    while j<m and i<n:
        if substring[j] == string[i]:
            j += 1
            i += 1
        elif j!=0:
            j = pnext[j-1]
        else:
            i += 1
    if j == m:
        return i-j
    else:
        return -1

KMP_algh('abgabcabgacyf','abcabgac')
#[out]:3

参考文章

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 今天看了kmp算法,最开始看得特别混乱,最后终于看明白了,想记录一下。https://github.com/hym...
    不会code的程序猿阅读 4,518评论 0 4
  • getnext函数: 用来给出指示:如果当前位置不匹配,要移动字串的位置多少。这里引入了最大前缀和后缀的概念。 K...
    BinJiang阅读 1,092评论 0 0
  • KMP算法是非常高知名度字符串匹配算法,也非常的牛P,具体在哪呢?这个算法每次我想起来的时候,我就要看一遍,自信的...
    NewFinalNull阅读 2,999评论 1 1
  • 阮一峰的文章字符串匹配算法:给定两个字符串A和B,问字符串A是否包含字符串B。 KMP算法 最简单的思路如下: 就...
    云彩修建站站长阅读 583评论 0 0
  • 异乡的人儿 在虚冷的月光下 想起了 那场初雪 雪花一片片 拼接了的 是这样一场 幻灭
    东望y阅读 858评论 0 3