菜单

Python字符串匹配算法KMP实例

2019年9月3日 - 理财婆高手论坛

Python字符串相配算法KMP实例,pythonkmp

本文实例呈报了Python字符串匹配算法KMP。分享给我们供大家参谋。具体如下:

#!/usr/bin/env python
#encoding:utf8
def next(pattern):
p_len = len(pattern)
pos = [-1]*p_len
j = -1
for i in range(1, p_len):
while j > -1 and pattern[j+1] != pattern[i]:
j = pos[j]
if pattern[j+1] == pattern[i]:
j = j + 1
pos[i] = j
return pos
def kmp(ss, pattern):
pos = next(pattern)
ss_len = len(ss)
pattern_len = len(pattern)
j = -1
for i in range(ss_len):
while j > -1 and pattern[j+1] != ss[i]:
j = pos[j]
if pattern[j+1] == ss[i]:
j = j + 1
if j == pattern_len-1:
print 'matched @: %s' % str(i-pattern_len+1)
j = pos[j]
kmp(u'上海自来水来自海上海', u'上海')

仰望本文所述对大家的Python程序设计有所补助。

本文实例叙述了Python字符串匹配算法KMP。分享给我们供我们仿效。具体如下:
#!/usr/bin/env python#encodi…

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图