我的(Android)Java程序中有一个字符串列表,我需要获取列表中对象的索引.问题是,我只能找到有关如何查找对象的第一个和最后一个索引的文档.如果我的列表中有3个或更多相同的对象怎么办?我怎样才能找到每个索引?
谢谢!
解决方法:
你需要进行暴力搜索:
static List indexesOf(List source, T target)
{
final List indexes = new ArrayList();
for (int i = 0; i < source.size(); i++) {
if (source.get(i).equals(target)) { indexes.add(i); }
}
return indexes;
}
请注意,这不一定是最有效的方法.根据上下文和列表的类型/大小,您可能需要进行一些严格的优化.关键是,如果您需要每个索引(并且对列表内容的结构一无所知),那么您需要在每个项目中进行死亡,以获得最佳O(n)成本.
根据底层列表的类型,get(i)可能是O(1)(ArrayList)或O(n)(LinkedList),因此这可能会导致O(n2)实现.您可以复制到ArrayList,也可以手动使用LinkedList递增索引计数器.
标签:android,java,list,indexing
来源: https://codeday.me/bug/20190723/1516812.html