香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > python >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

Python实现字符串匹配的KMP算法


时间:2022-04-02 10:27 作者:admin


kmp算法

KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法)。KMP算法的关键是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的。具体实现就是实现一个next()函数,函数本身包含了模式串的局部匹配信息。

#! /usr/bin/python/' target='_blank'>python# coding=utf-8"""基于这篇文章的Python实现http://blog.sae.sina.com.cn/archives/307"""import unittestdef pmt(s):  """  PartialMatchTable  """  prefix = [s[:i+1] for i in range(len(s)-1)]  postfix = [s[i+1:] for i in range(len(s)-1)]  intersection = list(set(prefix) & set(postfix))  if intersection:    return len(intersection[0])  return 0def kmp(big,small):  i = 0  while i < len(big) - len(small) + 1:    match = True    for j in range(len(small)):      if big[i+j] != small[j]:         match = False        break    if match:      return True    #移动位数 = 已匹配的字符数 – 对应的部分匹配值    if j:      i += j - pmt(small[:j])    else:      i += 1  return Falseclass kmpTests(unittest.TestCase):  def test_pmt(self):    self.assertEqual(pmt("A"),0)    self.assertEqual(pmt("AB"),0)    self.assertEqual(pmt("ABC"),0)    self.assertEqual(pmt("ABCD"),0)    self.assertEqual(pmt("ABCDA"),1)    self.assertEqual(pmt("ABCDAB"),2)    self.assertEqual(pmt("ABCDABD"),0)    self.assertEqual(pmt("AAAAAA"),5)  def test_kmp(self):    self.assertTrue(kmp("ABCD","CD"))    self.assertFalse(kmp("ABCD","BD"))    self.assertTrue(kmp("BBC ABCDAB ABCDABCDABDE","ABCDABD"))if __name__ == '__main__':  unittest.main()

总结

以上所述是小编给大家介绍的Python实现字符串匹配的KMP算法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)