0

0

怎么在Java中找出List中出现频率最高的元素_Map频率统计与Stream结合

P粉602998670

P粉602998670

发布时间:2026-03-18 09:39:31

|

174人浏览过

|

来源于php中文网

原创

最简洁的频率统计方案是用Collectors.groupingBy+Collectors.counting一行生成Map<String, Long>,但需确保元素重写equals/hashCode,注意返回Long类型、空列表处理、最高频元素遍历取值更可控,避免低效操作和未定义相等语义。

怎么在java中找出list中出现频率最高的元素_map频率统计与stream结合

Collectors.groupingBy + Collectors.counting 一行搞定频率统计

Java 8+ 最简洁的方案不是手写循环,而是靠 Stream 配合两个收集器组合。它自动把每个元素当 key,出现次数当 value,生成 Map<t long></t>

  • 必须确保元素类型重写了 equalshashCode,否则相同逻辑值可能被当成不同 key(比如自定义对象没重写就全算 distinct)
  • Collectors.counting() 返回的是 Long,不是 Integer,后续取最大值时别用 int 强转,容易溢出或抛 ClassCastException
  • List 会返回空 Map,不抛异常,但后续找最大值前得判空
Map<String, Long> freq = list.stream()
    .collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));

找频率最高的元素:Map.Entry 遍历比 maxBy 更稳

很多人直接链式调 .maxBy(Map.Entry.comparingByValue()),但要注意:如果多个元素并列最高频,它只返回其中一个(按迭代顺序),且返回的是 Optional,不判空会 NullPointerException

  • 更可控的做法是手动遍历 entrySet(),记录当前最大频次和对应元素;遇到相等频次可选择跳过、覆盖或收集全部(视业务而定)
  • 不要用 keySet() 再对每个 key 调 get() 查频次——重复查哈希表,O(n²) 时间
  • 如果 List 很大(>10⁵),避免在循环里反复装箱/拆箱 Long,可先用 long maxCount = 0 存基准值

TreeMapLinkedHashMap 不适合直接替代 HashMap 做频率统计

有人想靠 TreeMap 自动排序来省掉找最大值步骤,或者用 LinkedHashMap 记住插入顺序——这反而引入额外开销,且解决不了核心问题。

Ai好记
Ai好记

强大的AI音视频转录与总结工具

下载
  • TreeMap 插入是 O(log n),总统计时间从 O(n) 变成 O(n log n),纯属浪费
  • LinkedHashMap 插入顺序 ≠ 频次高低顺序,不能靠它“第一个就是最高频”
  • 真要排序,应该在统计完再对 entrySet()sorted(),而不是换 Map 实现类

原始类型数组或 int/long 场景别硬套 Stream<Integer>

如果处理的是 int[],转成 List<Integer> 再流式处理,会产生大量包装对象,GC 压力明显。这时候传统 for 循环 + HashMap<Integer, Integer> 更实际。

立即学习Java免费学习笔记(深入)”;

  • IntStream.of(arr).boxed().collect(...) 看似一行,但 boxing 成本高,尤其数组大时
  • 对于已知范围的整数(如 0~1000),用 int[] count = new int[1001] 数组计数,O(1) 查、O(n) 总耗时,快一个数量级
  • Stream 的优势在逻辑表达清晰,不在所有场景都性能最优
实际最常被忽略的点:**频率相等时的业务语义没定义清楚**。是任选一个?要最早出现的那个?还是全返回?这个逻辑不在统计代码里,而在你遍历 entrySet() 时怎么写比较条件——别等上线后才发现“最高频”结果每次都不一样。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1091

2023.08.02

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1091

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

619

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

355

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

235

2025.08.29

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

77

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

41

2025.11.16

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

17

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.5万人学习

C# 教程
C# 教程

共94课时 | 11.5万人学习

Java 教程
Java 教程

共578课时 | 83.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号