您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Python字符串匹配算法KMP实例

5b51 2022/1/14 8:21:03 python 字数 1183 阅读 481 来源 www.jb51.cc/python

本文实例讲述了Python字符串匹配算法KMP。分享给大家供大家参考。具体如下:

概述

本文实例讲述了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实例全部内容,希望文章能够帮你解决Python字符串匹配算法KMP实例所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶