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

题目:读取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));//定义缓冲流,加快读取速度
            String line=null; //数据一行一行的进行读取
            while ((line =br.readLine())!=null){//将读取的结果交给变量line,当读取的一行数据为null时循环结束
                String[] split = line.split(",");//将数据按照“,”进行分割
                //将数据放入集合中:
                for (String s:split) {
                    data.add(Integer.valueOf(s));//拿到的数据是字符串,强转数据类型
                }
            }
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
使用HashMap进行计数,key是数据、value是出现的次数:
 HashMap<Integer, Integer> hashMap = new HashMap<>();
        Iterator iterator = data.iterator();
        //通过遍历集合获取所有数据出现的次数
        while (iterator.hasNext()) {
            Integer i = (Integer) iterator.next();
            if (hashMap.containsKey(i)) {
                hashMap.put(i, hashMap.get(i) + 1);
            } else {
                hashMap.put(i, 1);
            }
        }
统计出现次数最多的6个数据: 
  PriorityQueue <Map.Entry <Integer, Integer>> priorityQueue = new PriorityQueue <>(6, new Comparator <Map.Entry <Integer, Integer>>() {
            @Override
            public int compare(Map.Entry <Integer, Integer> o1, Map.Entry <Integer, Integer> o2) {
                return o1.getValue() - o2.getValue();
            }
        });
遍历HashMap:
Iterator <Map.Entry <Integer, Integer>> iterator2 = hashMap.entrySet().iterator();
        while (iterator2.hasNext()) {
            Map.Entry <Integer, Integer> entry = iterator2.next();
            if (priorityQueue.size() < 6) {
                priorityQueue.add(entry);
            } else {
                //优先级队列中已经存在6个数据 ,小根堆,堆顶最小
                Map.Entry <Integer, Integer> entry1 = priorityQueue.peek();
                //比较出现次数
                if (entry.getValue() > entry1.getValue()) {
                    //当前元素大于堆顶元素,将堆顶元素删除,添加当前元素
                    priorityQueue.remove();
                    priorityQueue.add(entry);
                }
            }
        }

 打印数据:

Iterator<Map.Entry<Integer, Integer>> iterator1 = priorityQueue.iterator();
        while (iterator1.hasNext()) {
            Map.Entry<Integer, Integer> entry = iterator1.next();
            System.out.println("数据:" + entry.getKey() + "  出现次数:" + entry.getValue());
        }
  private static ArrayList<Integer> data=new ArrayList<>();
    public static void main(String[] args) {
        String path="D:/io作业/work.txt";
        readNum(path);
        count();
    }

 运行结果:

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
你可以通过以下步骤来统计文件每个单词出现次数: 1. 读取文件:使用Java文件读取功能,将待统计文件读入内存中。 2. 分离单词:将读入的文件内容按照空格、标点符号等分离成单词,可以使用Java的正则表达式来实现。 3. 统计单词数量:使用HashMap来存储每个单词出现次数,遍历每个单词,如果该单词已经在HashMap中存在,则将其出现次数加1,否则将该单词加入HashMap,并将其出现次数设为1。 4. 输出结果:遍历HashMap,输出每个单词及其出现次数。 以下是示例代码: ```java import java.io.BufferedReader; import java.io.FileReader; import java.util.HashMap; import java.util.Map; public class WordCount { public static void main(String[] args) { String filename = "test.txt"; // 待统计文件名 Map<String, Integer> wordCount = new HashMap<>(); // 用于存储单词出现次数HashMap // 读取文件 try (BufferedReader reader = new BufferedReader(new FileReader(filename))) { String line; while ((line = reader.readLine()) != null) { // 分离单词 String[] words = line.split("[\\p{Punct}\\s]+"); for (String word : words) { // 统计单词数量 if (wordCount.containsKey(word)) { wordCount.put(word, wordCount.get(word) + 1); } else { wordCount.put(word, 1); } } } } catch (Exception e) { e.printStackTrace(); } // 输出结果 for (Map.Entry<String, Integer> entry : wordCount.entrySet()) { System.out.println(entry.getKey() + ": " + entry.getValue()); } } } ``` 这个示例代码可以读取名为test.txt文件统计其中每个单词出现次数,并输出结果。你可以将其修改成符合你自己需求的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

心皿月

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

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

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

打赏作者

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

抵扣说明:

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

余额充值