java统计字符串中每个字符出现的个数

用treeMap集合来实现该案例

想法:

1.键盘录入一个字符串

2.创建TreeMap集合,键是Character,值是Integer

3.遍历字符串,得到每一个字符

4.拿到每一个字符作为键HashMap集合中去找对应的值,看其返回值

        注意:1.如果返回值是null:说明该字符在TreeMap集合中不存在,就把该字符作为键,1作为值存储。

                  2.如果返回值不是null:说明该字符在TreeMap集合中存在,把该值加一,然后重新存储该字符和对应的值

5.遍历TreeMap集合,得到键和值,按照要求进行拼接

6.输出结果

package test06;

import java.util.*;

public class HashMapDemo {
    public static void main(String[] args) {
        //键盘录入一个字符串
        Scanner sc=new Scanner(System.in);
        System.out.println("请输入一串字符串:");
        String line=sc.nextLine();

     //   HashMap<Character,Integer> map=new HashMap<Character,Integer>();
       //创建TreeMap集合,键是Character,值是Integer
        TreeMap<Character,Integer> map=new TreeMap<Character,Integer>();

       //遍历字符串,得到每一个字符
        for (int i=0;i<line.length();i++){
            char key=line.charAt(i);

            //拿到每一个字符作为键到TreeMap集合中去找对应的值,看其返回值
            Integer value=map.get(key);

            //如果返回值是null,说明该字符在TreeMap集合中不存在,就把该字符串作为键,1作为值存储
            if (value==null){
                map.put(key,1);

            }else {
                //如果返回值不是null,说明该字符在TreeMap集合中存在,把该值加一,然后重新存储该字符和对应的值
                value++;
                map.put(key,value);
            }
        }

        StringBuilder sb=new StringBuilder();

        Set<Character> keyset=map.keySet();
        //遍历TreeMap集合,得到键和值,按照要求进行拼接
        for (Character key:keyset){
            Integer value=map.get(key);
            sb.append(key).append("(").append(value).append(")");
        }
        //调用toString方法,从StringBuilder转为String类型输出
        String result=sb.toString();
        System.out.println(result);

    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值