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

2021/4/7 12:38:22

本文主要是介绍Java练习案例之输入一个字符串统计每个字母出现次数,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

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

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

需求:

键盘录入一个字符串,要求统计字符串中每个字符串出现的次数。
举例:键盘录入“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:输出结果

原码:

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());

    }
    
}



这篇关于Java练习案例之输入一个字符串统计每个字母出现次数的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程