题目:读取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));//定义缓冲流,加快读取速度