使用正则表达式统计并替换字符串中的字符

以前做过一个笔试题,要求是实现一个函数,对给出的字符串进行处理并返回,要求是给出的都是大写字母,对连续的多于一个的字母使用子母和字母出现的次数替换,例如给出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;
	}

}



经过测试,符合要求

你可能感兴趣的:(正则表达式,字符串替换)