如题:
字符串由英文字母组成,如“asdasqewqcccdddd”,要求只遍历一次找出其中连续2次及以上的字符串片段
上述字符串应输出“ccc,dddd”
public static void main(String[] args){
char[] s = "aaadasdccasdccccdddasddasqwecczcaaaaa".toCharArray();
StringBuffer sb = new StringBuffer();
for (int i = 0;i<s.length;i++){
//判断当前字符是否与后一个字符相同,或 与前一个字符相同
if ((i < s.length-1 && s[i] == s[i + 1] ) || (i > 0 && s[i] == s[i - 1])){
//使用StringBuffer拼接
//判断当前字符串 是否与 sb变量中的最后一个字符匹配,如不匹配则拼接逗号
if (sb.length() > 1 && !sb.substring(sb.length() - 1,sb.length()).equals(String.valueOf(s[i]))){
sb.append(",");
}
sb.append(s[i]);
}
}
System.out.println(sb);
}
输出结果: