標籤:style blog color 演算法 for new
String.indexOf的類比實現,沒想象中有多麼高深的尋找演算法,就是最普通的遍曆尋找
思路:先找到第一個相同的字元,然後依次比較後面的字元,若都相等則表示尋找成功
/** * 尋找字串pattern在str中第一次出現的位置 * @param str * @param pattern * @return */ public int firstIndexOf(String str, String pattern) { for (int i = 0; i < (str.length() - pattern.length()); i++) { int j = 0; while (j < pattern.length()) { if (str.charAt(i + j) != pattern.charAt(j)) break; j++; } if(j==pattern.length()) return i; } return -1; } /** * 尋找字串pattern在str中最後一次出現的位置 * @param str * @param pattern * @return */ public int lastIndexOf(String str, String pattern) { for (int i = str.length() - pattern.length(); i >= 0; i--) { int j = 0; while (j < pattern.length()) { if (str.charAt(i + j) != pattern.charAt(j)) break; j++; } if (j == pattern.length()) return i; } return -1; } /** * 尋找字串pattern在str中出現的位置 * @param str * @param pattern * @return */ public List<Integer> indexOf(String str, String pattern) { List<Integer> indexs = new ArrayList<Integer>(); for (int i = 0; i < (str.length() - pattern.length()); i++) { int j = 0; while (j < pattern.length()) { if (str.charAt(i + j) != pattern.charAt(j)) break; j++; } if (j == pattern.length()) indexs.add(i); } return indexs; }
同樣更常用的String.contains方法實際上就是調用的String.indexOf實現
/** * 判斷字串pattern在str中是否存在 * @param str * @param pattern * @return */ public boolean contains(String str, String pattern) { return firstIndexOf(str, pattern) != -1; }