假设我有一个字符串"aabbccaa"
。现在我想用另一个字符串替换给定字符串中"aa"
的出现次数。但它应该是以下列方式。
首次出现的"aa"
应由"1"
替换,下次出现的"aa"
应由"2"
替换,依此类推。
因此,字符串的结果变为"1bbcc2"
。
答案 0 :(得分:10)
您可以在计数器递增的for循环中使用replaceFirst()
...
for (int i = 1; string.contains("aa"); i++) {
string = string.replaceFirst("aa", "" + i);
}
答案 1 :(得分:5)
您可以使用Matcher
的{{3}}方法执行此操作:
Pattern p = Pattern.compile("aa");
Matcher m = p.matcher("aabbccaahhhaahhhaaahahhahaaakty");
StringBuffer sb = new StringBuffer();
// Variable "i" serves as a counter. It gets incremented after each replacement.
int i = 0;
while (m.find()) {
m.appendReplacement(sb, ""+(i++));
}
m.appendTail(sb);
System.out.println(sb.toString());
这种方法可以避免创建多个字符串对象(appendReplacement
)。
答案 2 :(得分:0)
可以使用Java函数,但使用char数组并使用较低级别的逻辑执行它会更快。
String s = "aabbccaa";
String target = "aa";
int i = 1;
String newS;
for (int j = 0; j < s.length; j++) {
newS = s.replaceFirst(target, i++);
j += newS.length - s.length;
s = newS;
}
答案 3 :(得分:0)
这是一个解决方案:
public static void main(String[] a) {
int i = 1;
String before = "aabbccaabbaabbaa";
String regex = "aa";
String after = substitute(i, before, regex);
System.out.println(after);
}
private static String substitute(int i, String before, String regex) {
String after = before.replaceFirst(regex, Integer.toString(i++));
while (!before.equals(after)) {
before = after;
after = before.replaceFirst(regex, Integer.toString(i++));
}
return after;
}
输出:
1bbcc2bb3bb4