1. 程式人生 > >indexOf原理,Java,javascript,python實現

indexOf原理,Java,javascript,python實現

 

簡介


  最近做專案的時候,發現無論是前端還是後端,indexOf出現的概率都非常頻繁,今天我們來看下他的實現原理吧!

  indexOf的含義:給定一個字串去匹配另一個字串的下標,如果匹配到,返回下標,如果匹配不到則返回-1,其實原理還是比較簡單的,如果需要你實現,那麼應該怎麼做呢?

 

原理


  現在給定匹配的字串A,原始字串B,比如匹配字串A等於“叫練”,原始字串B等於“邊叫邊練,我喜歡叫練”,你可能一眼就發現“叫練”是最後兩個字元,我們以B做迴圈,一個一個單詞去匹配,先找“叫”,找到計數器加1,然後繼續找“練”,發現下個字元不是“練”,計數器清零,重新從“叫”開始查詢,現在查詢到B的倒數第二個字元了,下個字元是“練”計算器再加1,此時計數器等於2也正好是A字串的長度,說明找到了,查詢原理就是這樣一個過程;下面我們分別以Java,javascript,python方式實現下。

  注意:下面程式碼沒有校驗,僅供參考,python是index方法,實現原理一樣,但找不到會報錯!

 

實現


Java實現

public static void main(String[] args) {
        String orgin = "邊叫邊練,我喜歡叫練";
        String serach = "叫練";
        int index = indexOf(orgin,serach);
        System.out.println(index);
    }

/**
     *  indexOf 演算法原理
     * @param orgin 原始字串 B = “邊叫邊練,我喜歡叫練”;
     * @param serachString 匹配字串 A=“叫練”
     * @return int 下標
     */
public static int indexOf(String orgin,String serachString) {
    char[] chars = orgin.toCharArray();
    char[] sChars = serachString.toCharArray();
    //返回字串下標
    int index = -1;
    //匹配字串計數器,用於查詢是否匹配到完整字串
    int s_index = 0;
    //全域性計數器,用於計算下標
    int move = 0;
    for (int i=0; i<chars.length; i++) {
        move++;
        //如果匹配到“叫”,繼續向下開始匹配“練”
        if (chars[i] == sChars[s_index]) {
            s_index++;
            if(s_index == sChars.length) {
                index = move-sChars.length;
                break;
            }
        } else {
            s_index = 0;
        }
    }
    return index;
}

 

Javascript實現

 1 /**
 2      * @param orgin 原始字串 B = “邊叫邊練,我喜歡叫練”;
 3      * @param serachString 匹配字串 A=“叫練”
 4      **/
 5     function indexOf(orgin,serachString) {
 6         //返回字串下標
 7         var index = -1;
 8         //匹配字串計數器,用於查詢是否匹配到完整字串
 9         var s_index = 0;
10         //全域性計數器,用於計算下標
11         var move = 0;
12         for (var i=0; i<orgin.length; i++) {
13             move++;
14             //如果匹配到“叫”,繼續向下開始匹配“練”
15             if (orgin.substr(i,1) == serachString.substr(s_index,1)) {
16                 s_index++;
17                 if(s_index == serachString.length) {
18                     index = move-serachString.length;
19                     break;
20                 }
21             } else {
22                 s_index = 0;
23             }
24         }
25         return index;
26     }

 

python實現

 1 # indexOf 演算法原理
 2 # @param orgin 原始字串 B = “邊叫邊練,我喜歡叫練”;
 3 # @param serachString 匹配字串 A=“叫練”
 4 # @return int 下標
 5 def index(orgin, serachString):
 6     # 返回字串下標
 7     index = -1
 8     # 匹配字串計數器,用於查詢是否匹配到完整字串
 9     s_index = 0
10     # 全域性計數器,用於計算下標
11     move = 0
12     for letter in enumerate(orgin):
13         move = move + 1
14         # 如果匹配到“叫”,繼續向下開始匹配“練”
15         if letter[1] == serachString[s_index]:
16             s_index = s_index + 1
17             if s_index == len(serachString):
18                 index = move - len(serachString)
19                 break
20         else:
21             s_index = 0;
22 
23     return index