找出某个String中出现次数最多的字符,并输出次数(字符较长)

5 篇文章 0 订阅

利用HashMap。
K 对应每一个字符;V对应相应的出现次数。

可用此思想解决 大数据情况下对 榜单音乐、搜索次数最多的词、等等的排序

代码如下

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

/**
 * Created by 功恒 on 2016/9/26 0026.
 */
public class Mostchar {
    public static void main(String[] args){
        String str = "aaabbBBBBcc";
        char[] chars = str.toCharArray();
        Map<Character,Integer> map=mapFun(chars);//存放好之后的map
        int max=0;
        for (int i=0;i<str.length();i++){
            if (max<map.get(chars[i])){
                max=map.get(chars[i]);
            }
        }
        System.out.print("max = "+max);
    }

    public static Map<Character,Integer>  mapFun (char[] chars){
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        if (chars != null&& chars.length!=0){
            for (int i=0;i<chars.length;i++){
                if (null!=map.get(chars[i])){
                     map.put(chars[i],map.get(chars[i])+1);
                }else {
                    map.put(chars[i],1);
                }
            }
        }
        return map;
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值