我正在寻找许多关于如何在有效的时间内获得2个集合的交集的查询。并寻找非常有效的方法。在探讨我自己的方法之前,为什么不能要求Java构建一个同样的方法来执行。为什么Java没有像sort方法那样在Collections类上或在Collections中的某个地方构建一个类似方法的交集?这背后有什么原因吗?
请认为这是关于集合上交集的拟合-下降的讨论。
谢谢,
发布于 2014-09-17 11:30:10
您必须找到2个集合之间最近的交集是retainAll()
。请注意,retainAll不会返回包含交集的新集合,而是修改调用它的Set实例。例如:
import java.util.HashSet;
import java.util.Set;
class Test2
{
public static void main(String[] args) {
Set<String> set1 = new HashSet<>();
set1.add("A");
set1.add("B");
Set<String> set2 = new HashSet<>();
set2.add("A");
set2.add("D");
set1.retainAll(set2);
System.out.println(set1);
}
}
https://stackoverflow.com/questions/25889278
复制相似问题