查找字符串中出现次数最多的字符

1、遍历对比

java 复制代码
public static Character findMostFrequentCharInString(String str) {
        if (StringUtils.isEmpty(str)) {
            return null;
        }
        Map<Character, Integer> map = new HashMap<>();
        char[] charArray = str.toCharArray();
        for (char c : charArray) {
            if (map.containsKey(c)) {
                map.put(c, map.get(c) + 1);
            } else {
                map.put(c, 1);
            }
        }
        // 找出最大值
        Integer max = Collections.max(map.values());
        // 遍历map找出key
        for (Map.Entry<Character, Integer> entry : map.entrySet()) {
            if (entry.getValue() == max) {
                return entry.getKey();
            }
        }
        return null;
    }

2、利用list排序

java 复制代码
public static Character findMostFrequentCharInString1(String str) {
        if (StringUtils.isEmpty(str)) {
            return null;
        }
        Map<Character, Integer> map = new HashMap<>();
        char[] charArray = str.toCharArray();
        for (char c : charArray) {
            if (map.containsKey(c)) {
                map.put(c, map.get(c) + 1);
            } else {
                map.put(c, 1);
            }
        }
        // 转换成List
        ArrayList<Map.Entry<Character, Integer>> list = new ArrayList<>(map.entrySet());
        // 按值倒序排列,第一个元素即为出现最多的字符和次数
        Collections.sort(list, (o1, o2) -> o2.getValue() - o1.getValue());
        return list.get(0).getKey();
    }

有没有小伙伴首先想到的是用自带排序的map,如TreeMap,直接使用自带方法

复制代码
map.firstEntry();
map.firstKey();
map.lastEntry();
map.lastKey();
获取最大最小值?
遗憾的是TreeMap是按key排序的。
相关推荐
jiayong23几秒前
第 43 课:任务详情抽屉里的批量处理闭环与删除联动
java·开发语言·前端
likerhood1 分钟前
Java 访问修饰符:public、protected、private讲解
java·开发语言·javascript
刀法如飞2 分钟前
JavaScript 数组去重的 20 种实现方式,学会用不同思路解决问题
前端·javascript·算法
Ting-yu4 分钟前
SpringCloud快速入门(5)---- 均衡负载
java·spring·spring cloud
洛水水10 分钟前
【力扣100题】46.单词拆分
算法·leetcode·职场和发展
学不思则罔21 分钟前
ParallelStream并发陷阱解析
java·开发语言·windows
认真的小羽❅25 分钟前
【Java并发编程】volatile关键字深度解析:从内存语义到实际应用
java·开发语言
奋斗的小乌龟39 分钟前
langchain4j笔记-08
java·spring boot·笔记
MicroTech202542 分钟前
量子安全赋能协同智能,微算法科技(NASDAQ :MLGO)研发PQS-BFL后量子区块链联邦学习框架
科技·算法·安全