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

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排序的。
相关推荐
gihigo1998几秒前
快速傅里叶变换(FFT)的应用
算法
做怪小疯子2 分钟前
LeetCode 热题 100——二叉树——对称二叉树 & 二叉树的直径
算法·leetcode·职场和发展
编程修仙2 分钟前
第二篇 搭建第一个spring程序
java·数据库·spring
麦麦鸡腿堡3 分钟前
Java_网络上传文件与netstat指令
java·服务器·网络
Pluchon3 分钟前
硅基计划4.0 算法 递归&回溯
算法·leetcode·决策树·深度优先·剪枝·广度优先·宽度优先
爱吃烤鸡翅的酸菜鱼5 分钟前
【RabbitMQ】发布订阅架构深度实践:构建高可用异步消息处理系统
java·spring boot·分布式·后端·websocket·架构·rabbitmq
念安jy6 分钟前
SDUT数据结构与算法pta--排序
算法
组合缺一7 分钟前
Solon AI 开发学习10 - chat - 工具调用概念介绍
java·人工智能·学习·ai·llm·solon
大江东去浪淘尽千古风流人物9 分钟前
【MSCKF】零空间 UpdaterHelper::nullspace_project_inplace 的实现细节,MSCKF边缘化含义
算法·性能优化·vr·dsp开发·mr
曼巴UE510 分钟前
UE5 C++ TSet 创建初始和迭代
java·c++·ue5