国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

python,Java,JavaScript實現indexOf

瀏覽:4日期:2022-07-11 17:43:54

簡介

最近做項目的時候,發現無論是前端還是后端,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實現

/** * @param orgin 原始字符串 B = “邊叫邊練,我喜歡叫練”; * @param serachString 匹配字符串 A=“叫練” **/ function indexOf(orgin,serachString) { //返回字符串下標 var index = -1; //匹配字符串計數器,用于查詢是否匹配到完整字符串 var s_index = 0; //全局計數器,用于計算下標 var move = 0; for (var i=0; i<orgin.length; i++) { move++; //如果匹配到“叫”,繼續向下開始匹配“練” if (orgin.substr(i,1) == serachString.substr(s_index,1)) {s_index++;if(s_index == serachString.length) { index = move-serachString.length; break;} } else {s_index = 0; } } return index; }

python實現

# indexOf 算法原理# @param orgin 原始字符串 B = “邊叫邊練,我喜歡叫練”;# @param serachString 匹配字符串 A=“叫練”# @return int 下標def index(orgin, serachString): # 返回字符串下標 index = -1 # 匹配字符串計數器,用于查詢是否匹配到完整字符串 s_index = 0 # 全局計數器,用于計算下標 move = 0 for letter in enumerate(orgin): move = move + 1 # 如果匹配到“叫”,繼續向下開始匹配“練” if letter[1] == serachString[s_index]: s_index = s_index + 1 if s_index == len(serachString):index = move - len(serachString)break else: s_index = 0; return index

以上就是python,Java,JavaScript實現indexOf的詳細內容,更多關于indexOf的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 欧美国产综合日韩一区二区 | 日本加勒比系列 | 亚洲无卡视频 | 久操影视 | 欧美jizzhd极品欧美 | 美国三级视频 | 男人女人做刺激视频免费 | 毛片国产| 国产精品毛片va一区二区三区 | 久久在线一区 | 99久久精品免费看国产高清 | 亚洲网站视频在线观看 | 免费毛片全部不收费的 | 一级毛片播放 | 日韩一级欧美一级毛片在线 | 日韩城人视频 | 色婷婷色综合激情国产日韩 | 久热国产在线视频 | 久久久久久91香蕉国产 | 亚洲欧美自拍一区 | 成人做爰视频www视频 | 久久se精品一区二区国产 | 国产成人精品亚洲2020 | 国产亚洲精品国产第一 | 国产毛片久久精品 | 欧美性高清bbbbbbxxxxx | 国产高清日韩 | 国产一级久久久久久毛片 | 国产区一区二区三区 | 欧美.亚洲.日本一区二区三区 | 日韩视频在线观看 | 深夜福利视频在线观看 | 日韩一区二区三区在线观看 | 久久成人精品免费播放 | 精品欧美一区二区在线观看 | 综合欧美视频一区二区三区 | 国产在线拍揄自揄视精品不卡 | 久久爰www免费人成 久久曰视频 | 在线欧美一级毛片免费观看 | 性夜黄a爽爽免费视频国产 性夜影院爽黄a爽免费看网站 | 成人毛片免费视频 |