news 2026/4/18 8:09:38

317. Java Stream API - 使用 groupingBy() 构建直方图并提取最大值

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
317. Java Stream API - 使用 groupingBy() 构建直方图并提取最大值

文章目录

  • 317. Java Stream API - 使用 `groupingBy()` 构建直方图并提取最大值
      • ✅ Part 1:构建直方图(Histogram)
      • ✅ Part 2:提取最大值(提取出现次数最多的字符串长度)
        • 📌 方法一:用 `Map.Entry` 直接找最大值
      • ⚠️ Part 3:多个最大值时如何处理?
      • ✅ Part 4:如何提取所有最大值(Map 反转技巧)
    • ✅ 总结

317. Java Stream API - 使用groupingBy()构建直方图并提取最大值

✅ Part 1:构建直方图(Histogram)

我们有一个字符串列表,想要统计每种字符串长度的出现次数。这个任务可以通过Collectors.groupingBy配合Collectors.counting()来完成:

Collection<String>strings=List.of("one","two","three","four","five","six","seven","eight","nine","ten","eleven","twelve");Map<Integer,Long>histogram=strings.stream().collect(Collectors.groupingBy(String::length,Collectors.counting()));histogram.forEach((length,count)->System.out.println(length+" :: "+count));

🖨 输出:

3::44::35::36::2

🔍 说明:

  • String::length是分组键:字符串的长度。
  • Collectors.counting()是统计该组中元素的数量。
  • 最终结果是一个直方图:键是字符串长度,值是该长度出现的次数。

✅ Part 2:提取最大值(提取出现次数最多的字符串长度)

📌 方法一:用Map.Entry直接找最大值

我们想要从直方图中找到数量最多的那组。例如上面例子中,3 :: 4是数量最多的(长度为3的字符串有4个)。

Map.Entry<Integer,Long>maxValue=histogram.entrySet().stream().max(Map.Entry.comparingByValue()).orElseThrow();System.out.println("maxValue = "+maxValue);

🖨 输出:

maxValue=3=4

📌 小技巧:

  • entrySet().stream()是将 Map 转换为流。
  • Map.Entry.comparingByValue()是基于值的比较器。
  • orElseThrow()是保险措施,避免空结果。

⚠️ Part 3:多个最大值时如何处理?

如果出现多个 key 拥有相同的最大 value,那么上面方法只能选出一个,其他会被忽略。例如:

Collection<String>strings=List.of("two","three","four","five","six","seven","eight","nine","ten","eleven","twelve");

输出的直方图:

3::34::35::36::2

👀 问题:有三个长度(3、4、5)的字符串数量都是 3。

如果你用.max(),只会返回其中之一,可能会遗漏其他候选最大值。


✅ Part 4:如何提取所有最大值(Map 反转技巧)

🎯 思路: 我们可以将直方图反转,把 “数量” 作为 key,“长度” 作为 value(或 List of value):

Map<Long,List<Integer>>reversed=histogram.entrySet().stream().collect(Collectors.groupingBy(Map.Entry::getValue,// 用 count 作为 keyCollectors.mapping(Map.Entry::getKey,// 收集 lengthCollectors.toList())));

然后找出最大 key,对应的 List 就是所有最大值:

LongmaxCount=reversed.keySet().stream().max(Long::compare).orElseThrow();List<Integer>lengthsWithMaxCount=reversed.get(maxCount);System.out.println("最大数量 = "+maxCount+",对应长度 = "+lengthsWithMaxCount);

🖨 输出:

最大数量=3,对应长度=[3,4,5]

✅ 总结

操作目标推荐方法
构建直方图(统计数量)groupingBy(..., counting())
提取唯一最大值(value 最大)entrySet().stream().max(comparingByValue())
提取多个最大值(存在并列最大)Map 反转 +groupingBy+max(keySet())
提升可读性使用 Java 16+ 的record
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 20:03:34

项目实践:XinServer 的备份恢复机制非常好用

项目实践&#xff1a;XinServer 的备份恢复机制非常好用 最近跟几个创业的朋友聊天&#xff0c;他们都在吐槽一件事&#xff1a;每次项目上线前&#xff0c;或者服务器要动点啥&#xff0c;心里就发毛。为啥&#xff1f;怕数据丢了呗。数据库备份这事儿&#xff0c;说大不大&am…

作者头像 李华
网站建设 2026/4/18 7:28:58

计算机毕业设计springboot基于的蔬菜市场在线交易系统 基于微服务架构的社区生鲜配送管理平台 Spring Boot框架下的智慧农贸数字化交易系统

计算机毕业设计springboot基于的蔬菜市场在线交易系统l4ds655u &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。 随着互联网技术的深度渗透和城乡居民消费习惯的数字化转型&#…

作者头像 李华
网站建设 2026/4/16 13:44:16

中文最特别的地方:藏在文字里的东方智慧,刻进骨子里的思考方式

中文最特别的地方&#xff1a;藏在文字里的东方智慧&#xff0c;刻进骨子里的思考方式中文从不是简单的交流符号&#xff0c;而是藏着中国人千年智慧的文化载体&#xff0c;它以独有的文字逻辑&#xff0c;悄悄塑造着我们看待世界、表达自我的方式&#xff0c;那些看似琐碎的用…

作者头像 李华
网站建设 2026/4/18 5:59:59

DeepChat智能运维助手:日志异常检测系统

DeepChat智能运维助手&#xff1a;日志异常检测系统效果展示 1. 这不是普通日志分析&#xff0c;而是会思考的运维大脑 你有没有经历过这样的深夜&#xff1a;服务器告警声此起彼伏&#xff0c;日志文件像瀑布一样刷屏&#xff0c;而你盯着成千上万行文本&#xff0c;眼睛发酸…

作者头像 李华