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

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排序的。
相关推荐
CoovallyAIHub10 分钟前
【技术前沿】减少90%人工!基于3D GPR深度学习的道路健康监测技术解析
深度学习·算法·计算机视觉
wwjdr27 分钟前
彻底搞懂Iterable 和 Iterator
java·面试
添乱27 分钟前
「Java案例」利用方法打印乘法表
java
界面开发小八哥33 分钟前
「Java EE开发指南」如何用MyEclipse创建企业应用项目?(一)
java·ide·java-ee·eclipse·myeclipse
添乱35 分钟前
「Java案例」利用方法求反素数
java
wwjdr36 分钟前
彻底搞懂 Comparable 和 Comparator
java·面试
Code季风37 分钟前
深入理解 Spring 设计模式:从实现原理到思想精髓
java·spring·设计模式
GuGu202440 分钟前
泛型知识理解
java
大葱白菜43 分钟前
Java 字符集(Charset)详解:从编码基础到实战应用,彻底掌握字符处理核心机制
java·后端·程序员
日月星辰Ace44 分钟前
通过 Spring WebFlux 源码分析装饰器模式
java·spring boot