以前做过一个笔试题,要求是实现一个函数,对给出的字符串进行处理并返回,要求是给出的都是大写字母,对连续的多于一个的字母使用子母和字母出现的次数替换,例如给出AAK那么返回的是A2K,下面使用正则表达式完成。
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class ReplaceTest {
public static void main(String[] args) {
System.out.println(test("AASDDDSSSAAJJJKKKKKKFGFJJJJTTTKDDDDBBSSSA"));
}
public static String test(String str) {
String regex = "";
for (char base = 'A'; base<='Z'; base++) {
regex = base + "{2,}";
Pattern p = Pattern.compile(regex);
Matcher m = p.matcher(str);
while (m.find()) {
String matche = m.group();
str = str.replace(matche,matche.charAt(0) + "" + matche.length());
}
}
return str;
}
}
经过测试,符合要求