最近作項目的時候,發現不管是前端仍是後端,indexOf出現的機率都很是頻繁,今天咱們來看下他的實現原理吧!javascript
indexOf的含義:給定一個字符串去匹配另外一個字符串的下標,若是匹配到,返回下標,若是匹配不到則返回-1,其實原理仍是比較簡單的,若是須要你實現,那麼應該怎麼作呢?前端
如今給定匹配的字符串A,原始字符串B,好比匹配字符串A等於「叫練」,原始字符串B等於「邊叫邊練,我喜歡叫練」,你可能一眼就發現「叫練」是最後兩個字符,咱們以B作循環,一個一個單詞去匹配,先找「叫」,找到計數器加1,而後繼續找「練」,發現下個字符不是「練」,計數器清零,從新從「叫」開始查找,如今查找到B的倒數第二個字符了,下個字符是「練」計算器再加1,此時計數器等於2也正好是A字符串的長度,說明找到了,查找原理就是這樣一個過程;下面咱們分別以Java,javascript,python方式實現下。java
注意:下面代碼沒有校驗,僅供參考,python是index方法,實現原理同樣,但找不到會報錯!python
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; }
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 }
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