统计txt文件中每个字符出现的次数,并根据次数从高到低排序

使用HashMap来存放信息

/*
 * @Description //main函数
 * @Param
 * @return
 **/


import java.io.*;
import java.util.*;


public class HelloServer {
        public static void main(String[] args) throws IOException {
                HashMap<Character, Integer> map = new HashMap<>();
                File txtFile = new File("C:\\Users\\Administrator\\Desktop\\test.txt");
                FileInputStream fr = new FileInputStream(txtFile);
                InputStreamReader isr = new InputStreamReader(fr);
                BufferedReader br = new BufferedReader(isr);
                int len;
                while ((len = br.read()) != -1) {
                        map.put((char) len, map.get((char) len) == null ? 1 : (map.get((char) len) + 1));
                }

                System.out.println(hashMapSort(map));


        }

        //接收一个HashMap  排序后在返回该HashMap
        public static HashMap<Character, Integer> hashMapSort(HashMap<Character, Integer> map) {
                //1、按顺序保存map中的元素,使用LinkedList类型

                List<Map.Entry<Character, Integer>> keyList = new LinkedList<Map.Entry<Character, Integer>>(map.entrySet());
                //2、按照自定义的规则排序

                Collections.sort(keyList, new Comparator<Map.Entry<Character, Integer>>() {
                        @Override
                        public int compare(Map.Entry<Character, Integer> o1, Map.Entry<Character, Integer> o2) {
                                if (o2.getValue().compareTo(o1.getValue()) < 0) {
                                        return 1;
                                } else if (o2.getValue().compareTo(o1.getValue()) > 0) {
                                        return -1;
                                } else {
                                        return 0;
                                }
                        }

                });

                //3、将LinkedList按照排序好的结果,存入到HashMap中
                HashMap<Character, Integer> result = new LinkedHashMap<>();
                for (Map.Entry<Character, Integer> entry : keyList) {
                        result.put(entry.getKey(), entry.getValue());
                }
                return result;
        }
}

转载于:https://my.oschina.net/u/4100033/blog/3051845

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个Java程序,可以实现统计文本文件字符出现次数并按照出现次数排序的功能: ```java import java.io.*; import java.util.*; public class ChineseCharCount { public static void main(String[] args) { String filename = "test.txt"; // 待统计文件名 Map<Character, Integer> charMap = new HashMap<>(); // 用于存储字符出现次数的映射 try (BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(filename), "UTF-8"))) { String line; while ((line = reader.readLine()) != null) { for (int i = 0; i < line.length(); i++) { char c = line.charAt(i); if (isChineseChar(c)) { Integer count = charMap.get(c); if (count == null) { charMap.put(c, 1); } else { charMap.put(c, count + 1); } } } } } catch (IOException e) { e.printStackTrace(); } List<Map.Entry<Character, Integer>> charList = new ArrayList<>(charMap.entrySet()); // 将映射转换为列表 charList.sort((e1, e2) -> e2.getValue().compareTo(e1.getValue())); // 按照出现次数从大到小排序 for (Map.Entry<Character, Integer> entry : charList) { System.out.println(entry.getKey() + ": " + entry.getValue()); } } // 判断一个字符是否为字符 private static boolean isChineseChar(char c) { Character.UnicodeBlock ub = Character.UnicodeBlock.of(c); return ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS; } } ``` 程序首先读取指定的文本文件,逐行遍历文件的每个字符,如果一个字符字符,则将其加入到一个映射,并记录其出现次数。最后,将映射转换为列表并按照出现次数从大到小排序,输出结果。 程序使用了`isChineseChar`方法来判断一个字符是否为字符,该方法判断的依据是该字符所属的`UnicodeBlock`是否为字符所使用的`UnicodeBlock`。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值