黑马程序员JavaAPI16天8(TreeMap练习字母出现的次数)

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;
    }
}
原文地址:https://www.cnblogs.com/guwenren/p/2970825.html