Java练习案例之输入一个字符串统计每个字母出现次数

Java小案例:输入一个字符串,要求统计字符串中每个字符串出现的次数

  • 需求:
    • 结果预览:
    • 思路:
    • 原码:

需求:

键盘录入一个字符串,要求统计字符串中每个字符串出现的次数。
举例:键盘录入“aababcabcdabcde”
在控制台输出:“a(5)b(4)c(3)d(2)e(1)"

结果预览:

Java练习案例之输入一个字符串统计每个字母出现次数_第1张图片

思路:

1 :键盘录入一个字符串
2:创建HashMap集合,键是character,值是Integer
3:遍历字符串,得到每一个字符
4 :拿得到的每一个字符作为键到HashMap集合中去找对应的值,看其返回值
如果返回值是null,说明该字符在HashMap集合中不存在,就把该字符作为键,1作为值存储
如果返回值不是null,说明该字符在HashMap集合中存在,把该值加1,然后重新存储该字符和对应的值
5:遍历HashMap集合,得到键和值,按照要求进行拼接
6:输出结果

原码:

package 小案例练习.简单案例;
import java.util.*;
/*需求:
键盘录入一个字符串,要求统计字符串中每个字符串出现的次数。
举例:键盘录入“aababcabcdabcde”在控制台输出:“a(5)b(4)c(3)d(2)e(1)"
思路:
1 :键盘录入一个字符串
2:创建HashMap集合,键是character,值是Integer
3:遍历字符串,得到每一个字符
4 :拿得到的每一个字符作为键到HashMap集合中去找对应的值,看其返回值
如果返回值是null,说明该字符在HashMap集合中不存在,就把该字符作为键,1作为值存储
如果返回值不是null,说明该字符在HashMap集合中存在,把该值加1,然后重新存储该字符和对应的值
5:遍历HashMap集合,得到键和值,按照要求进行拼接
6:输出结果
*/
public class Test26StringTimes {
    public static void main(String[] args) {
        //从键盘录入
        System.out.println("请输入一个字符串");
        Scanner sc =new Scanner(System.in);
        String s = sc.nextLine();
        //创建HashMap集合对象(键值无排序)  TreeMap有排序
        TreeMap<Character,Integer> hm=new TreeMap<>();
        //遍历字符串
        for(int i=0;i<s.length();i++){
            char key = s.charAt(i);
            //拿得到的每一个字符作为键到HashMap集合中去找对应的值,看其返回值
            Integer value = hm.get(key);
            if(value ==null){

                hm.put(key,1);
            }else{
                value++;
                hm.put(key,value);

            }
        }
        //遍历集合
     
        StringBuilder sb=new StringBuilder();
        Set<Character> keySet = hm.keySet();
        for(Character key:keySet){

            Integer value = hm.get(key);
            sb.append(key).append("(").append(value).append(")");

        }
        System.out.println(sb.toString());

    }
    
}

你可能感兴趣的:(JavaSE,字符串,hashmap)