「克努斯-莫里斯-普拉特演算法(Knuth–Morris–Pratt algorithm / KMP algorithm)」是一種字串搜尋演算法(string-searching algorithm),可用來在一長串文字中,尋找特定字串。 匹配陣列(PS Array) 用來比較一字串中的內容重複出現的程度;在比較兩字串時,若兩字串不相符,匹配陣列(PS Array)可協助將比較的字串往後移。
一:BF算法 如果让你写字符串的模式匹配,你可能会很快的写出朴素的bf算法,至少问题是解决了,我想大家很清楚的知道它的时间复 杂度为O(MN),原因很简单,主串和模式串失配的时候,我们总是将模式串的第一位与主串的下一个字符进行比较,所以复杂 度高在主串每次失配的时候都要回溯,图我就省略了。 二:KMP算法 ...