KMP python实现
首先去 https://blog.csdn.net/starstar1992/article/details/54913261/ 这里看下思想;
然后代码实现,一定要多调试几遍方能看懂:
def gen_pnext(p):
i, k, m = 0, -1, len(p)
pnext = [-1] * m #初始化数组元素全为-1,-1表示当前元素之前的字符串相同的最大前缀和最大后缀元素个数
while i < m-1: #不能超过模式数组的长度
print('i=',i)
print('p[i]=',p[i])
print('k=',k)
print('p[k]=',p[k])
print('pnext=',pnext)
if k == -1 or p[i] == p[k]: #k=-1表示还没对相应位置的元素求移动量,
# p[i]==p[k]表示当前元素与k位置元素相等(第一次时k肯定为0),
# 然后i,k同时后移继续比较元素个数。
# k=0表示前后最大相同字串个数为0,k=1表示有1个相同的,k=2表示有2个
i, k = i+1, k+1
pnext[i] = k
else:
k = pnext[k]
return pnext
t = 'abbcabca'
p = 'abbcabc'
print(gen_pnext(p))
完整代码:
def matching_KMP(t, p, pnext):
j, i = 0, 0
n, m = len(t), len(p)
while j < n and i < m:
if i == -1 or t[j] == p[i]:
j, i = j+1, i+1
else:
i = pnext[i]
if i == m:
return j - 1
return -1 def gen_pnext(p):
i, k, m = 0, -1, len(p)
pnext = [-1] * m #初始化数组元素全为-1,-1表示当前元素之前的字符串相同的最大前缀和最大后缀元素个数
while i < m-1: #不能超过模式数组的长度
print('i=',i)
print('p[i]=',p[i])
print('k=',k)
print('p[k]=',p[k])
print('pnext=',pnext)
if k == -1 or p[i] == p[k]: #k=-1表示还没对相应位置的元素求移动量,
# p[i]==p[k]表示当前元素与k位置元素相等(第一次时k肯定为0),
# 然后i,k同时后移继续比较元素个数。
# k=0表示前后最大相同字串个数为0,k=1表示有1个相同的,k=2表示有2个
i, k = i+1, k+1
pnext[i] = k
else:
k = pnext[k]
return pnext
t = 'abbcabca'
p = 'abbcabc'
print(gen_pnext(p))
print(matching_KMP(t,p,gen_pnext(p)))
如有疑问,欢迎留言!
KMP python实现的更多相关文章
- 字符串匹配的KMP算法——Python实现
#! /usr/bin/python # coding=utf-8 """ 基于这篇文章的python实现 http://blog.sae.sina.com.cn/arc ...
- 流动python - 字符串KMP匹配
首先我们看一下简单的字符串匹配. 你可以把文本字符串s固定,模式字符串p从s对齐的左边缘,作为承担部分完全一致,匹配成功,失败将是模式字符串p整体向右1地点,继续检查对齐部分,重复. #朴素匹配 de ...
- kmp算法python实现
kmp算法python实现 kmp算法 kmp算法用于字符串的模式匹配,也就是找到模式字符串在目标字符串的第一次出现的位置比如abababc那么bab在其位置1处,bc在其位置5处我们首先想到的最简单 ...
- 字符串匹配的kmp算法 及 python实现
一:背景 给定一个主串(以 S 代替)和模式串(以 P 代替),要求找出 P 在 S 中出现的位置,此即串的模式匹配问题. Knuth-Morris-Pratt 算法(简称 KMP)是解决这一问题的常 ...
- 字符串匹配算法之 kmp算法 (python版)
字符串匹配算法之 kmp算法 (python版) 1.什么是KMP算法 KMP是三位大牛:D.E.Knuth.J.H.MorriT和V.R.Pratt同时发现的.其中第一位就是<计算机程序设计艺 ...
- KMP算法-Python版
KMP算法-Python版 传统法: 从左到右一个个匹配,如果这个过程中有某个字符不匹配,就跳回去,将模式串向右移动一位.这有什么难的? 我们可以 ...
- Python 细聊从暴力(BF)字符串匹配算法到 KMP 算法之间的精妙变化
1. 字符串匹配算法 所谓字符串匹配算法,简单地说就是在一个目标字符串中查找是否存在另一个模式字符串.如在字符串 "ABCDEFG" 中查找是否存在 "EF" ...
- [ Python ] KMP Algorithms
def pmt(s): """ :param s: the string to get its partial match table :return: partial ...
- BF算法和KMP算法 python实现
BF算法 def Index(s1,s2,pos = 0): """ BF算法 """ i = pos j = 0 while(i < ...
随机推荐
- LeetCodeOJ刷题之14【Longest Common Prefix】
Longest Common Prefix Write a function to find the longest common prefix string amongst an array of ...
- 最重要的“快捷键” IntelliJ IDEA
转载:http://www.youmeek.com/intellij-idea-part-iii-hotkeys-explain/ @IntelliJ IDEA第三部分视频教程:最重要的“快捷键”专讲 ...
- windows网络模型之重叠IO(完成例程)的使用
#include <WINSOCK2.H> #include <stdio.h> #define PORT 5150 #define MSGSIZE 1024 #pragma ...
- POJ 1986 Distance Queries 【输入YY && LCA(Tarjan离线)】
任意门:http://poj.org/problem?id=1986 Distance Queries Time Limit: 2000MS Memory Limit: 30000K Total ...
- POJ 2365【YY水题】
题目链接:POJ 2365 Rope Rope Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7488 Accepted ...
- idea连接sqlite
首先下载驱动 官网链接:http://mvnrepository.com/artifact/org.xerial/sqlite-jdbc 打开idea 第一步:右边 数据源 (如果没有显示单击这里,有 ...
- Android学习笔记_73_授权过程
.需要申请App Key和App Secret.不同的开发平台有不同的接入方式,可以参考文档,然后将这两个值放进去. .通过OAuth类实现认证,它会自动跳转到认证界面,进行授权,成功之后需要处理回调 ...
- Android学习笔记_31_通过后台代码生成View对象以及动态加载XML布局文件到LinearLayout
一.布局文件part.xml: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android&qu ...
- webpack4——打包html报错解决
①先引入html-webpack-plugin插件,然后在终端下载 npm install --save-dev html-webpack-plugin ②我的文件结构 ③修改webpack.dev. ...
- Restframework的认证,权限,节流
1.认证 流程:请求到达REST framework的时候,会对request进行二次封装,在封装的过程中会对客户端发送过来的request封装进认证,选择,解析等功能.request方法封装完成之后 ...