如何在没有迭代的情况下获取给定LinkedHashSet元素的索引? [英] How to obtain index of a given LinkedHashSet element without iteration?
问题描述
甚至可能吗?
假设你有
private Set<String> names = new LinkedHashSet<String>();
和字符串
是Mike,约翰,凯伦。
and Strings
are "Mike", "John", "Karen".
是否有可能在没有迭代的情况下获得1以回答约翰的索引是什么?
Is it possible to get "1" in return to "what's the index of "John" without iteration?
以下工作正常..有了这个问题,我想知道是否有更好的方式
The following works fine .. with this question i wonder if there is a better way
for (String s : names) {
++i;
if (s.equals(someRandomInputString)) {
break;
}
}
推荐答案
设置
界面没有像 indexOf()
方法。你真的需要迭代它或使用 列表
接口而不是提供 indexOf()
方法。
The Set
interface doesn't have something like as an indexOf()
method. You'd really need to iterate over it or to use the List
interface instead which offers an indexOf()
method.
如果你想要将设置
转换为列表
非常简单,这应该是通过通过
。例如, List
实现的构造函数设置
If you would like to, converting Set
to List
is pretty trivial, it should be a matter of passing the Set
through the constructor of the List
implementation. E.g.
List<String> nameList = new ArrayList<String>(nameSet);
// ...
这篇关于如何在没有迭代的情况下获取给定LinkedHashSet元素的索引?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!