KMP演算法的JavaScript實現

來源:互聯網
上載者:User

  剛才看到新聞頻道轉截的一篇文章:阮一峰:字串匹配的KMP演算法,圖文並茂通俗易懂,就用JS實現了一下,現分享出來。

  演算法的核心是部分匹配表和回退演算法,部分匹配表的實現如下:

function kmpGetStrPartMatchValue(str) {    var prefix = [];    var suffix = [];    var partMatch = [];    for(var i=0,j=str.length;i<j;i++){        var newStr = str.substring(0,i+1);        if(newStr.length == 1){            partMatch[i] = 0;        } else {            for(var k=0;k<i;k++){                prefix[k] = newStr.slice(0,k+1);                suffix[k] = newStr.slice(-k-1);                if(prefix[k] == suffix[k]){                    partMatch[i] = prefix[k].length;                }            }            if(!partMatch[i]){                partMatch[i] = 0;            }        }    }    prefix.length = 0;    suffix.length = 0;    return partMatch;}//demovar t="ABCDABD";console.log(kmpGetStrPartMatchValue(t));//output:[0,0,0,0,1,2,0]

  回退演算法實現如下:

function KMP(sourceStr,targetStr){    var partMatchValue = kmpGetStrPartMatchValue(targetStr);    var result = false;    for(var i=0,j=sourceStr.length;i<j;i++){        for(var m=0,n=targetStr.length;m<n;m++){            if(str.charAt(m) == sourceStr.charAt(i)){                if(m == targetStr.length-1){                    result = true;                    break;                } else {                    i++;                }            } else {                if(m>0 && partMatchValue[m-1] > 0){                    m = partMatchValue[m-1]-1;                } else {                    break;                }            }        }        if(result){            break;        }    }    return result;}var s = "BBC ABCDAB ABCDABCDABDE";var t = "ABCDABD";console.log(KMP(s,t));//output: true

  歡迎交流討論。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.