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; } }