编写java程序统计一篇英语文档中个单词出现的次数,并按单词出现频率由高到低进行输出;
时间: 2023-04-07 21:05:16 浏览: 315
好的,这是一个技术问题,我可以回答。您可以使用Java中的HashMap来实现单词计数。首先,您需要将文档中的所有单词拆分为单独的字符串,并将它们存储在一个字符串数组中。然后,您可以遍历该数组并使用HashMap来存储每个单词的出现次数。最后,您可以按照单词出现频率从高到低对HashMap进行排序,并将结果输出。
相关问题
1.编写Java程序统计一篇英文文档中各单词出现的次数,并按单词出现的频率由高到低进行输出。 例如:文档“Hello word Hello”的统计结果为: Hello:2次 word:1次
好的,我可以为您编写这个Java程序。以下是程序代码:
```java
import java.io.File;
import java.io.FileNotFoundException;
import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.TreeMap;
public class WordCount {
public static void main(String[] args) {
File file = new File("文档路径"); // 请替换为您要统计的文档路径
Map<String, Integer> wordCountMap = new HashMap<>();
try {
Scanner scanner = new Scanner(file);
while (scanner.hasNext()) {
String word = scanner.next().replaceAll("[^a-zA-Z]", "").toLowerCase();
if (word.length() > 0) {
if (wordCountMap.containsKey(word)) {
wordCountMap.put(word, wordCountMap.get(word) + 1);
} else {
wordCountMap.put(word, 1);
}
}
}
scanner.close();
} catch (FileNotFoundException e) {
System.out.println("找不到指定的文件");
e.printStackTrace();
}
Map<String, Integer> sortedWordCountMap = new TreeMap<>((o1, o2) -> {
int countCompare = wordCountMap.get(o2) - wordCountMap.get(o1);
if (countCompare == 0) {
return o1.compareTo(o2);
} else {
return countCompare;
}
});
sortedWordCountMap.putAll(wordCountMap);
for (Map.Entry<String, Integer> entry : sortedWordCountMap.entrySet()) {
System.out.println(entry.getKey() + ":" + entry.getValue() + "次");
}
}
}
```
请将上述代码中的“文档路径”替换为您要统计的文档的实际路径,并运行程序即可得到统计结果。
阅读全文