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

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排序的。
相关推荐
重生之后端学习1 分钟前
146. LRU 缓存
java·数据结构·算法·leetcode·职场和发展
程曦曦3 分钟前
原地删除有序数组重复项:双指针法的艺术与实现
数据结构·算法·leetcode
萧曵 丶3 分钟前
懒加载单例模式中DCL方式和原理解析
java·开发语言·单例模式·dcl
你怎么知道我是队长4 分钟前
C语言---排序算法6---递归归并排序法
c语言·算法·排序算法
回忆是昨天里的海6 分钟前
k8s部署的微服务动态扩容
java·运维·kubernetes
萧曵 丶7 分钟前
单例模式 7 种实现方式对比表
java·单例模式
智驱力人工智能16 分钟前
景区节假日车流实时预警平台 从拥堵治理到体验升级的工程实践 车流量检测 城市路口车流量信号优化方案 学校周边车流量安全分析方案
人工智能·opencv·算法·安全·yolo·边缘计算
lang2015092817 分钟前
Tomcat Maven插件全解析:开发部署一体化
java·tomcat·maven
MicroTech202518 分钟前
微算法科技(NASDAQ :MLGO)抗量子攻击区块链共识机制:通过量子纠缠态优化节点验证流程,降低计算复杂度
科技·算法·区块链
pp起床19 分钟前
贪心算法 | part01
算法·贪心算法