java练习之获取字符串中每个字符出现的次数

练习题:输入某个字符串,获取该字符串中每个字符出现的次数。
思路:字符和次数之间存在映射关系。使用TreeMap集合。
由于操作字符的关系,先将字符串转化为字符数组。对字符数组进行遍历,用每一个键作为key去map中查询。如果该字母键不存在,就将该字母作为键,值为1存储到map集合中。如果该字母键存在,就将该字母对应的值加1,并将加1后的值存储到map中,这样就会覆盖原来的值,从而记录字母出现的次数。
 

代码如下:

public class MapTest {
      public static void main(String[] args) {
           String str = "udhuchfuefv";
           String s = getStringCount(str);
           System.out.println(s);
           }
      public static String getStringCount(String str) {
            //将字符串转化为字符数组
            char[] ss = str.toCharArray();
             //定义map集合
            Map<Character,Integer> map = new TreeMap<Character,Integer>();
             //遍历字符数组
            for (int i = 0; i < ss.length; i++) {
                   Integer value =  map.get(ss[i]);  
             //使用字符数组中的 元素作为key,去查询对应的value
            if(value == null)
               {map.put(ss[i], 1); //如果该字符对应的value为0,置1}
            else
                {map.put(ss[i], value+1); //如果value值不为空,自加1}
           }
          return mapToString(map);
          }
      public static String mapToString(Map<Character, Integer> map) {
           StringBuilder sbu = new StringBuilder();
           Set<Character> key = map.keySet();
           Iterator it = key.iterator();
           while(it.hasNext())
           {
              Character k = (Character)it.next();
              Integer value = map.get(k);
             sbu.append(k+"("+value+")");
           }
               return sbu.toString();
         }
}

猜你喜欢

转载自blog.csdn.net/weixin_42139212/article/details/84429631