字符串匹配—KMP算法
发布时间:2021-05-21 07:26:25 所属栏目:大数据 来源: https://www.jb51.cc
导读:KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt提出的,因此人们称它为克努特—莫里斯—普拉特操作(简称KMP算法)。KMP算法的核心是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的。具体实现就是通过
KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt提出的,因此人们称它为克努特—莫里斯—普拉特操作(简称KMP算法)。KMP算法的核心是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的。具体实现就是通过一个next()函数实现,函数本身包含了模式串的局部匹配信息。KMP算法的时间复杂度O(m+n) 。 public class KMP { static int[] GetNext(String ps) { char[] p = ps.ToArray(); int[] next = new [p.Length]; next[0] = -1; int j = 0int k = -while (j < p.Length - ) { if (k == -1 || p[j] == p[k]) { next[++j] = ++k; } else { k = next[k]; } } return next; } GetIndex(String ts,String ps) { char[] t = ts.ToArray(); int i = 0; // 主串的位置 模式串的位置 int[] next = GetNext(ps); while (i < t.Length && j < p.Length) { if (j == -1 || t[i] == p[j]) { 当j为-1时,要移动的是i,当然j也要归0 i++; j++; } { i不需要回溯了 i = i - j + 1; j = next[j]; j回到指定位置 } } if (j ==return i - j; } { return -; } } } test void Main(string[] args) { Console.WriteLine( KMP.GetIndex("abcdbcxdbc",dbc")); Console.ReadKey(); } ? ? (编辑:北几岛) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |