bf算法和kmp算法的優(yōu)缺點(diǎn) kmp算法什么意思?
kmp算法什么意思?KMP算法之所以被稱(chēng)為KMP算法,是因?yàn)檫@個(gè)算法是由三個(gè)人提出的,取三個(gè)人名字的首字母作為算法的名字。實(shí)際上,KMP算法與BF算法的區(qū)別在于,KMP算法巧妙地消除了指針I(yè)的回溯問(wèn)題
kmp算法什么意思?
KMP算法之所以被稱(chēng)為KMP算法,是因?yàn)檫@個(gè)算法是由三個(gè)人提出的,取三個(gè)人名字的首字母作為算法的名字。實(shí)際上,KMP算法與BF算法的區(qū)別在于,KMP算法巧妙地消除了指針I(yè)的回溯問(wèn)題,只需確定下一個(gè)匹配J的位置,將問(wèn)題的復(fù)雜度從O(MN)降低到O(MN)。在KMP算法中,為了在匹配失敗時(shí)確定J在下一次匹配中的位置,引入了next[]數(shù)組。next[J]的值表示P[0]中最長(zhǎng)后綴的長(zhǎng)度。。。J-1]等于相同字符序列的前綴。next[]數(shù)組的定義如下:1)next[J]=-1,J=0.2)next[J]=max(k):0<K<J P[0。。。K-1]=P[J-K,J-1]3)next[J]=0,例如:P a B a J 0.12.34 next-1.001 2,即next[J]=K>0時(shí),表示P[0。。。K-1]=P[J-K,J-1]。因此,KMP算法的思想是:在匹配過(guò)程中,如果存在不匹配,如果next[J]>=0,則目標(biāo)字符串的指針I(yè)不變,模式字符串的指針J移到next[J]的位置繼續(xù)匹配;如果next[J]=-1,則I移到右邊,將j設(shè)置為0以繼續(xù)比較。
什么時(shí)候用bf算法好,什么時(shí)候用kmp算法好?
如果要匹配的模式字符串中幾乎沒(méi)有重復(fù)字符,則BF正常。普通字符串幾乎是這樣的。當(dāng)模式串中存在多個(gè)重復(fù)子串時(shí),KMP的效率比BF高很多