package string.test;
/*
* 练习:获取"aaaccccbbbbb"字符串中字母出现的次数如下
* a(3)b(5)c(4)
* 当发现有映射关系时,可以选择map集合。
* 因为map集合中存放就是映射关系。
* 当数据之间存在这种映射关系时,就要先想到map集合
* 思路
* 1,将字符串转换成字符数组。因为要对每一个字母经行操作
* 2,定义一个map集合,因为打印结果的字母有顺序,所以使用treeMap集合
* 3,遍历字符数组
* 将每一个字母作为键去查map集合
* 如果返回null,将该字母和1存入到map集合中。
* 如果返回不是null,说明该字母在map集合中已经存在并有了对应的次数。
* 那么就获取该次数并经行自增,然后将该字母和自增后的次数存入到map集合中。覆盖原来键所对应的值
* 4,将map集合中的数据以字符串方式返回
*/
import java.util.*;
public class MapDemo6 {
public static void main(String[] args) {
String s = charCount("aaaccccbbbbb");
System.out.println(s);
}
public static String charCount(String str) {
if (str != null && !"".equals(str)) {
char[] chars = str.toCharArray();
Map<Character, Integer> map = new TreeMap<Character, Integer>();
for (int i = 0; i < chars.length; i++) {
Integer value = map.get(chars[i]);
map.put(chars[i], value == null ? 1 : (value + 1));
}
StringBuilder sb = new StringBuilder();
Set<Map.Entry<Character, Integer>> entrySet = map.entrySet();
Iterator<Map.Entry<Character, Integer>> iterator = entrySet.iterator();
while (iterator.hasNext()) {
Map.Entry<Character, Integer> me = iterator.next();
Character key = me.getKey();
Integer value = me.getValue();
sb.append(key).append("(").append(value).append(")");
}
return sb.toString();
}
return null;
}
}