在對字符串的操作中,我們經(jīng)常要用到子串的查找功能,我們稱子串為模式串,模式串在主串中的查找過程我們成為模式匹配,KMP算法就是一個(gè)高效的模式匹配算法。KMP算法是蠻力算法的一種改進(jìn),下面我們先來介紹蠻力算法。

  蠻力算法使用兩個(gè)int型變量當(dāng)做當(dāng)前匹配位置的指針,我們假設(shè)主串的位置指針為i,模式串的位置指針為j。蠻力算法的策略便是在i和j所指的位置的字符相等時(shí),繼續(xù)向后匹配,當(dāng)發(fā)生失配時(shí),便將i回溯到本次匹配前位置的后一個(gè)位置,而將j設(shè)置為0,從而對所有位置完成逐一比對,通過觀察i和j是否越界判斷整體匹配是否成功,若模式串位置指針j越界,顯然此前所有位置都已完全匹配,那么也就可以返回i-j也即完全匹配時(shí)主串中匹配子串的下標(biāo)位置。

萬碼學(xué)堂,電腦培訓(xùn),計(jì)算機(jī)培訓(xùn),Java培訓(xùn),JavaEE開發(fā)培訓(xùn),青島軟件培訓(xùn),軟件工程師培訓(xùn)

int brute(char * mString ,char * subString) {        int i = 0 ,j = 0;        int m = strlen(mString),
            n = strlen(subString);        while ( i < m &&j < n) {            if (mString[i] == subString[j]) {
                i++;
                j++;
            }            else {
                i -= j - 1;
                j = 0;
            }
        }if (j >= n)            return i - j;
     if