我有两套同类型的A和B。
我必须找出A是否包含集合B中的任何元素。
不遍历集合的最好方法是什么? Set库有contains(object)和containsAll(collection),但没有containsAny(collection)。
我有两套同类型的A和B。
我必须找出A是否包含集合B中的任何元素。
不遍历集合的最好方法是什么? Set库有contains(object)和containsAll(collection),但没有containsAny(collection)。
当前回答
在Set接口中使用retainAll()。此方法提供了两个集合中公共元素的交集。有关更多信息,请参阅API文档。
其他回答
实现集合的containsAny的一个好方法是使用Guava sets .intersection()。
containsAny将返回一个布尔值,因此调用如下所示:
Sets.intersection(set1, set2).isEmpty()
如果集合不相交,返回true,否则返回false。这种方法的时间复杂度可能比retainAll稍微好一些,因为您不必做任何克隆来避免修改原始集。
不收藏。(A, B)工作脱节?从文档中可以看到:
如果两个指定的集合没有共同的元素,则返回true。
因此,如果集合包含任何公共元素,则该方法返回false。
您可以使用retainAll方法获取两个集合的交集。
在Set接口中使用retainAll()。此方法提供了两个集合中公共元素的交集。有关更多信息,请参阅API文档。
我使用org.apache.commons.collections.CollectionUtils
CollectionUtils.containsAny(someCollection1, someCollection2)
就是这样! 如果两个集合中至少有一个元素,则返回true。
使用简单,函数名更具启发性。