package HashTable;
/**
* 统计一篇给定的文章中,各个单词出现的次数的算法。
* 用HashMap 来存放出现的单词的次数,Key 是要统计的单词,Value 是单词出现的次数。
* 后再按照 Key 的升序排列出来。
*/
import java.util.*;
import java.io.*;
public class CountOccurrenceOfWords {
public static void main(String[] args) throws Exception {
Map hashMap = null;
BufferedReader infile = null;
StringTokenizer st = null;
String filename = "Test.txt";
String string;
String file = null;
infile = new BufferedReader(new FileReader(filename));
while ((string = infile.readLine()) != null) {
file += string; // 都出整篇文章,存入String中。
}
hashMap = new HashMap();
// 取出文章中的单词,"," "." "!" " " 为各个单词的分界符。
st = new StringTokenizer(file, " ,.!");
while (st.hasMoreTokens()) {
String key = st.nextToken();
if (hashMap.get(key) != null) { //当key不为空的时候,value加一
int value = ((Integer) hashMap.get(key)).intValue();
value++;
hashMap.put(key, new Integer(value));
} else { //当key值为空的时候,将value设置为1
hashMap.put(key, new Integer(1));
}
}
//这个是没有排序的
Set entrySet2 = hashMap.entrySet();
Iterator iter = entrySet2.iterator();
while(iter.hasNext()){
System.out.println(iter.next());
}
// 按照单词的字母次序输出。
Map treeMap = new TreeMap(hashMap);
Set entrySet = treeMap.entrySet();
Iterator iterator = entrySet.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next());
}
}
}
- Java可以开发什么游戏?
- 北大青鸟Java软件开发学什么?学Java难吗
- 武汉哪里有Java软件开发学校_北大青鸟Java软件开发全面升级
- 武汉哪里有Java软件开发学校_北大青鸟Java软件开发全面升级
- 北大青鸟Java好不好?零基础可以学会吗?
- 武汉北大青鸟Java培训怎么样啊?费用多少?
- 学电脑学什么好?JAVA软件开发怎么样?
- 武汉北大青鸟Java软件培训班怎么样?
- java语言基础之java开发中需要了解的概念
- Java教程:Linux与Windows下的Java开发区别
看过该Java开发的还看过
本文标题:#Java开发教程 文章中单词出现次数的算法#,宏鹏发布于北大青鸟鲁广校区。Java软件开发教程,如何统计一篇给定的文章中,各个单词出现的次数的算法。