首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >高效的EnumSet +列表

高效的EnumSet +列表
EN

Stack Overflow用户
提问于 2010-05-20 17:31:49
回答 2查看 720关注 0票数 1

有人知道EnumSet + List的一个很好的解决方案

我的意思是,我需要存储枚举值,还需要保持顺序,并且能够在O(1)时间内访问集合中枚举值的索引。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-05-20 17:54:45

我能想到的最接近的东西是API中出现的LinkedHashSet

来自http://java.sun.com/j2se/1.4.2/docs/api/java/util/LinkedHashSet.html

哈希表和链表实现的Set接口,具有可预测的迭代顺序。

我怀疑做你想做的事是不可能的。基本上,您希望在固定时间内查找索引,即使在修改了列表的顺序之后也是如此。除非您允许删除/重新排序操作花费O(n)时间,否则我相信您不可能在低于O(log )的情况下逃脱惩罚(这可以通过堆结构来实现)。

票数 2
EN

Stack Overflow用户

发布于 2010-05-20 17:42:33

我能看到的满足排序和O(1)访问的惟一方法是将数据复制到一个List和一个索引数组中(当然,包装在一个漂亮的小OrderedEnumSet中)。

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

https://stackoverflow.com/questions/2872484

复制
相关文章

相似问题

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