Java實(shí)現(xiàn)字符串匹配的示例代碼
java實(shí)現(xiàn)字符串匹配
暴力匹配
/** * 暴力匹配 * * @param str1 需要找的總字符串 * @param str2 需要找到的字符串 * @return 找到的字符串的下標(biāo) */ private static int violence(String str1, String str2) { char[] s1 = str1.toCharArray(); char[] s2 = str2.toCharArray(); int s1Len = s1.length; int s2Len = s2.length; // 指針,分別指向兩個(gè)字符串 int i = 0; int j = 0; // 保證匹配時(shí)不越界 while (i < s1Len && j < s2Len) { // 第一個(gè)字符匹配上了 if (s1[i] == s2[j]) { ++i; ++j; } else { i -= (j - 1); j = 0; } } // 判斷是否成功 if (j == s2Len) { return i - j; } else { return -1; }
KMP算法
/** * KMP算法 * * @param str1 源字符串 * @param str2 子串 * @param next 匹配值表 * @return 對(duì)應(yīng)下標(biāo),沒有為-1 */ private static int kmp(String str1, String str2, int[] next) { for (int i = 0, j = 0; i < str1.length(); ++i) { while (j > 0 && str1.charAt(i) != str2.charAt(j)) { j = next[j - 1]; } if (str1.charAt(i) == str2.charAt(j)) { j++; if (j == str2.length()) { return i - j + 1; } return -1; } * @return dest的部分匹配表 private static int[] getkmpNext(String dest) { int length = dest.length(); int[] next = new int[length]; next[0] = 0; for (int i = 1, j = 0; i < length; i++) { while (j > 0 && dest.charAt(i) != dest.charAt(j)) { if (dest.charAt(i) == dest.charAt(j)) { next[i] = j; return next;
到此這篇關(guān)于Java實(shí)現(xiàn)字符串匹配的文章就介紹到這了,更多相關(guān)java字符串匹配內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringMVC中的DispatcherServlet結(jié)構(gòu)和初始化詳解
這篇文章主要介紹了SpringMVC中的DispatcherServlet結(jié)構(gòu)和初始化詳解,SpringMVC中Spring容器的關(guān)系是通過監(jiān)聽方式啟動(dòng)的,那么Spring與Servlet的Web容器(如:Tomcat、jetty)的關(guān)系則是通過DispatcherServlet進(jìn)行關(guān)聯(lián),需要的朋友可以參考下2024-01-01淺談Spring Cloud zuul http請(qǐng)求轉(zhuǎn)發(fā)原理
這篇文章主要介紹了淺談Spring Cloud zuul http請(qǐng)求轉(zhuǎn)發(fā)原理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08使用Spring的攔截器監(jiān)測(cè)每個(gè)Controller或方法的執(zhí)行時(shí)長(zhǎng)
這篇文章主要介紹了使用Spring的攔截器監(jiān)測(cè)每個(gè)Controller或方法的執(zhí)行時(shí)長(zhǎng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10JAVA線程sleep()和wait()詳解及實(shí)例
這篇文章主要介紹了JAVA線程sleep()和wait()詳解及實(shí)例的相關(guān)資料,探討一下sleep()和wait()方法的區(qū)別和實(shí)現(xiàn)機(jī)制,需要的朋友可以參考下2017-05-05詳解Mybatis攔截器安全加解密MySQL數(shù)據(jù)實(shí)戰(zhàn)
本文主要介紹了Mybatis攔截器安全加解密MySQL數(shù)據(jù)實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01java實(shí)現(xiàn)單鏈表倒轉(zhuǎn)的方法
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)單鏈表倒轉(zhuǎn)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05