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

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排序的。
相关推荐
4***17276 分钟前
Spring Boot中Tomcat配置
java
源代码•宸16 分钟前
Golang语法进阶(协程池、反射)
开发语言·经验分享·后端·算法·golang·反射·协程池
Chan1637 分钟前
场景题:CPU 100% 问题怎么排查?
java·数据库·redis·后端·spring
qq_336313931 小时前
java基础-IO流(网络爬虫/工具包生成假数据)
java·爬虫·php
桦说编程1 小时前
滑动窗口限流器的演进之路:从调度器实现到 Packed CAS
java·后端·性能优化
开开心心_Every2 小时前
安卓后台录像APP:息屏录存片段,行车用
java·服务器·前端·学习·eclipse·edge·powerpoint
初次攀爬者2 小时前
SpringBoot 整合 JWT + Redis 实现登录鉴权
java·redis·后端
悦悦妍妍2 小时前
spring-ioc
java
Jasmine_llq2 小时前
《CF280C Game on Tree》
数据结构·算法·邻接表·深度优先搜索(dfs)·树的遍历 + 线性累加统计