java treemap截取_java – 获取TreeMap中的三个最高值

我试图在TreeMap中找到三个最高值.我编写了一个代码,但是我想问一下你是否可以提出一种更有效的方法.

基本上,我在TreeMap中保存文本的每个单词以及它在文本中出现的次数.然后我使用比较器对值进行排序.然后我迭代新创建的Map,直到我到达最后三个值,这是排序后的最高值并打印出来.我将使用大文本,所以这不是一个很好的方法.

这是我的代码:

class Text{

public static void main(String args[]) throws FileNotFoundException, IOException{

final File textFile = new File("C://FileIO//cinderella.txt");

final BufferedReader in = new BufferedReader(new FileReader(textFile));

final TreeMap frequencyMap = new TreeMap();

String currentLine;

while ((currentLine = in.readLine()) != null) {

currentLine = currentLine.toLowerCase();

final StringTokenizer parser = new StringTokenizer(currentLine, " \t\n\r\f.,;:!?'");

while (parser.hasMoreTokens()) {

final String currentWord = parser.nextToken();

Integer frequency = frequencyMap.get(currentWord);

if (frequency == null) {

frequency = 0;

}

frequencyMap.put(currentWord, frequency + 1);

}

}

System.out.println("This the unsorted Map: "+frequencyMap);

Map sortedMap = sortByComparator(frequencyMap);

int i = 0;

int max=sortedMap.size();

StringBuilder query= new StringBuilder();

for (Iterator it = sortedMap.entrySet().iterator(); it.hasNext();) {

Map.Entry entry = (Map.Entry) it.next();

i++;

if(i<=max && i>=(max-2)){

String key = entry.getKey();

//System.out.println(key);

query.append(key);

query.append("+");

}

}

System.out.println(query);

}

private static Map sortByComparator(TreeMap unsortMap) {

List list = new LinkedList(unsortMap.entrySet());

//sort list based on comparator

Collections.sort(list, new Comparator() {

public int compare(Object o1, Object o2) {

return ((Comparable) ((Map.Entry) (o1)).getValue())

.compareTo(((Map.Entry) (o2)).getValue());

}

});

//put sorted list into map again

Map sortedMap = new LinkedHashMap();

for (Iterator it = list.iterator(); it.hasNext();) {

Map.Entry entry = (Map.Entry)it.next();

sortedMap.put(entry.getKey(), entry.getValue());

}

return sortedMap;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值