# -*- 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字符串匹配算法
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...