Java输出字符串出现次数最多的字母

import java.util.HashMap;
import java.util.Map;

public class Demo03MapStringMaxNumber {
    public static void main(String[] args) {
        String str = "kdjjkjbJhd";
        // 如果不分大小写
        str = str.toLowerCase(); // 将字母全部变成小写,并返回一个新的字符串
        int res = 0;
        char resC = str.charAt(0);
        Map<Character, Integer> hashMap = new HashMap<>();
        for (int i = 0; i < str.length(); i++) {
            if (hashMap.containsKey(str.charAt(i))){ // 判断该字母是否已经存在字典,如果是 value+1
                hashMap.put(str.charAt(i), hashMap.get(str.charAt(i))+1);
            }
            else{
                hashMap.put(str.charAt(i), 1); // 将字母添加到字典中
            }
            // 需要输出出现次数最多的字母的次数和字母
            if (res < hashMap.get(str.charAt(i))){
                res = hashMap.get(str.charAt(i));
                resC = str.charAt(i);
            }
            //res = Math.max(res, hashMap.get(str.charAt(i)));  // 如果只需要输出出现次数最多的字母次数,就写这一句就好了
        }
        System.out.println("字母 " + resC+" 出现的次数最多,一共出现了 "+res+ " 次");
    }
}

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值