A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 陈山 中级黑马   /  2012-11-8 21:41  /  3828 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

// 需求:"cbxzbvavdvgd"获取字符串中,每一个字母出现次数:a(1)b(2)c(1)d(2)g(1)v(3)x(1)z(1)

public class TreeMapTest {
    public static void main(String[] args) {
        String str = "cbxzbvavdvgd";
        // 写一个功能,完成每个字符数据的统计
       TreeMap<Character, Integer> tm = stringToTreeMap(str);
        // 把TreeMap变成字符串
        String s = treeMapToString(tm);
        System.out.println(s);
     }
     // 把TreeMap变成字符串
     private static String treeMapToString(TreeMap<Character, Integer> tm) {
          StringBuilder sb = new StringBuilder();
          Set<Character> set = tm.keySet();
          Iterator<Character> it = set.iterator();
          while (it.hasNext()) {
          Character key = it.next();
          Integer value = tm.get(key);
          sb.append(key).append("(").append(value).append(")");
           }
      return sb.toString();
    }
     // 把字符串变成TreeMap
      private static TreeMap<Character, Integer> stringToTreeMap(String str) {
          TreeMap<Character, Integer> tm = new TreeMap<Character, Integer>();
          // 遍历字符串,获取每个字符
          for (int x = 0; x < str.length(); x++) {
          // 获取每个字符值
          char ch = str.charAt(x);
          Integer i = tm.get(ch); // 自动装箱
          // 如果没有数据,那么, 返回的是null,返回null的时候,我们就把该字符存入Map中
          if (i == null) {
                  tm.put(ch, 1);
          } else {
                   // 有数据
                   i++; // 先拆箱,在装箱
                   tm.put(ch, i);
              }
           }
            return tm;
      }
}

评分

参与人数 1技术分 +1 收起 理由
古银平 + 1 很给力!

查看全部评分

1 个回复

倒序浏览
值得学习ing!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马