IO流 练习题(三)——读取文件,统计每个数据出现的次数,并打印出现次数最多的6个数据

本文讲解了如何使用Java通过IO流读取work.txt文件,利用HashMap统计每个数字出现的次数,并借助PriorityQueue找出出现次数最多的6个数据。重点涉及数据读取、哈希表操作和优先级队列的运用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:读取work.txt文件,统计每个数据出现的次数,并打印出现次数最多的6个数据

文件内容如下:

23,45,4556,68,8934,3
456,68,9,789,90,324,5
343,7678,242,234
12,6,789,34,89,45,34,24
234,56,78,89,9,3434,23
12,24,46,68,7,8945342,2134
23,45,56,68,79,9,324,342434
21,342,4,76,7987,987,2345
124,234,34,457,6778,58
124,335,567

这道题需要用IO流集合 相结合来解决问题,使用缓冲流对文件中的数据进行读取;使用hashmap进行计数,然后使用优先级队列统计出现次数最多的数据,集合部分涉及到的知识点和代码和这篇文章中的相同

有1万个数据,数据范围在1~1000之内,统计出现次数最多的5个数据,打印数据及出现的次数_心皿月的博客-CSDN博客

思路如下:

第一步:完成文件的读取,获取数字

第二步:使用HashMap进行计数

第三步:使用PriorityQueue统计出现次数最多的6个数据

读取文件中的数据:


    public static void readNum(String path) {
        try {
            BufferedReader br = new BufferedReader(new FileReader(path));//定义缓冲流,加快读取速度
 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心皿月

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值