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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
/**
* 计算一个字符串中每个字符出现的次数
*
* 思路:
* 通过toCharArray()拿到一个字符数组-->
* 遍历数组,将数组元素作为key,数值1作为value存入map容器-->
* 如果key重复,通过getKey()拿到value,计算value+1后存入
*/
public class Test01 {
    public static void main(String[] args) {
        System.out.println("请输入字符串:");
        Scanner sc=new Scanner(System.in);
        while (sc.hasNextLine()){
            String str=sc.nextLine();
            Map<Character,Integer> map =count(str);
            System.out.println(map);
        }
    }
    public static Map<Character,Integer> count(String str){
        Map<Character,Integer> map=new HashMap<Character,Integer>();
        char[] array_char=str.toCharArray();//把字符串转成字符数组
        for(char  arr_char: array_char){//遍历字符数组
            if(map.containsKey(arr_char)){//查看字符是否在map的key中存在,如果存在
                Integer old=map.get(arr_char);//通过key获取value的值
                map.put(arr_char,old+1);//把字符放入map的key中,value设置为通过key获取value的值+1
            }else{//查看字符是否在map的key中存在,如果不存,把字符放入map的key中,value默认设置为1
                map.put(arr_char,1);
            }
        }
        return  map;
    }
}
---------------------
【转载,仅作分享,侵删】
作者:小志的博客  
原文:https://blog.csdn.net/li1325169021/article/details/88606051
版权声明:本文为博主原创文章,转载请附上博文链接!

1 个回复

倒序浏览
奈斯,感谢分享
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马