python KMP

'''starryj'''


import time


def kmp_next(pattern):
    """得到部分匹配表
    A B C D A B D
    0 0 0 0 1 2 0"""
    next = [int(0)]
    for i in range(1, len(pattern)):
        pa = pattern[:i + 1]
        if pa[0] == pa[-1]:
            x = 1
        else:
            x = 0
        for p in range(1, i):
            if pa[:i + 1 - p] == pa[p:]:
                x = i + 1 - p
            else:
                continue
        next.append(x)

    return next


strings = 'ABC ABCDAB ABCDABCDABDE'
pattern = 'abcabcacab'
#  strings = 'hello world!'
#  pattern = 'world'
print(kmp_next(pattern))


def matching_kmp(strings, pattern, index):
    s = len(strings)
    p = len(pattern)
    j = 0
    i = 0
    while j < s and i < p:
        if strings[j] == pattern[i]:
            j, i = j + 1, i + 1
        elif strings[j] != pattern[0]:
            j += 1
        else:
            if index[i - 1] != 0:
                j -= index[i - 1]
            else:
                j += 1
            i = index[i]
    if i == p:
        return j - i
    else:
        return '没有匹配的'
t1 = time.time()
index = kmp_next(pattern)
t = matching_kmp(strings, pattern, index)
print(t)
print(time.time() - t1)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值