有如下的一个字符串,请统计出其中每一个字母出现的次数

public class StringDemo {
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String str= "QWERTYQQUIQQQWJHDAADADBBBBCAD";
		countLetter(str);
	}
	/**
	 * 1.统计字符串中每一个字母出现的次数
	 * 2.请打印出字母次数最多的那一对
	 * @param str
	 */
	public static void countLetter(String str){
		char[] charArray = str.toCharArray();
		HashMap<Character, Integer> hashMap = new HashMap<Character,Integer>();
		for (char c : charArray) {
			//把字符变量c作为键添加到hashMap中,使用containsKey()方法判断集合中是否有c键,
			//使用!非,如果没有则加入值1,如果有则通过key取出值再加1
			hashMap.put(c, !hashMap.containsKey(c) ? 1 : (hashMap.get(c)+1));
		}
		Set<Entry<Character,Integer>> entrySet = hashMap.entrySet();
		Integer max = 0;
		Character c = ' ';
		//使用hashMap中的entrySet()方法获得键值对对象,再循环遍历
		for (Entry<Character, Integer> entry : entrySet) {
			if(max < entry.getValue()){
				max = entry.getValue();
				c = entry.getKey();
			}
			System.out.println(entry.getKey() + "===" + entry.getValue());
		}
		System.out.println("打印字母次数最多的:" + c + "-----" + max);
	}
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值