首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Java TreeMap中检索N个最相关的对象

在Java TreeMap中检索N个最相关的对象
EN

Stack Overflow用户
提问于 2014-10-28 13:59:39
回答 1查看 79关注 0票数 1

根据this question,我订购了Java Map,如下所示:

代码语言:javascript
复制
ValueComparator bvc =  new ValueComparator(originalMap);
Map<String,Integer> sortedMap = new TreeMap<String,Integer>(bvc);
sortedMap.putAll(originalMap);

现在,我想以top-K的方式从地图中提取K最相关的值。有没有一种高效的方法可以避免迭代映射呢?

一些类似的问题(例如,this)要求解决顶部-1的检索问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-28 14:05:07

不,如果你使用Map的话就不会了。你得反复考虑一下。

你考虑过使用PriorityQueue吗?这是Java的堆实现。它具有插入任意元素和删除“最低限度”的有效操作。你可能会考虑在这里做这个。而不是Map,您可以将它们放入按关联排序的PriorityQueue中,其中最相关的作为根。然后,要提取最相关的K,只需从PriorityQueue中弹出K元素。

如果您需要类似于映射的属性(从String映射到Integer),那么您可以编写一个类,在内部将所有东西保存在PriorityQueueHashMap中。插入时,插入两个元素;当删除最小元素时,从PriorityQueue中弹出,然后告诉您还需要从HashMap中删除哪个元素。这仍将为您提供日志时间插入和最小删除。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26610265

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档