字符串搜索之KMP算法(伪代码)

  之前的Rabin-Karp算法虽然在一定程度上达到了优化,但是最坏情况下也是O(nm)的复杂度。

  接下来说说KMP算法,复杂度是线性的O(n+m)

 前缀表
• 我们可以预先计算大小为m的前缀表来存储p[q]的
   值 (0 <=q < m)

    P      p  a  p  p  a  r

    q  0  1  2  3  4  5  6

p[q]  0  0  0  1  1  2  0


Knuth-Morris-Pratt  算法
KMP-Search(T,P)
01 pi <- Compute-Prefix-Table(P) //预处理前缀表P
02 q <- 0                // number of characters matched
03 for i <- 0 to n-1 // scan the text from left to right
04   while q > 0 and P[q] <> T[i] do
05            q <- p[q]
06   if P[q] = T[i] then q <- q + 1
07   if q = m then return i – m + 1
08 return –1
 Compute-Prefix-Table 是P 上执行KMP 算法的本质.


KMP 的分析
• 最坏运行时间: O(n+m)
– 主算法: O(n)
– Compute-Prefix-Table: O(m)
• 空间: O(m)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值