也就是说,如果我有两个或更多集合,并且我想返回一个包含以下任一集合的新集合:
每个集合的所有元素都有共同点(AND).
每组(OR)的所有元素总数.
每组的所有元素都是独一无二的.(XOR).
是否有一种简单的,预先存在的方法可以做到这一点?
编辑: 这是错误的术语,不是吗?
假设2设置对象a和b
AND(两组交集)
a.retainAll(b);
或(两套联合)
a.addAll(b);
XOR要么滚动你自己的循环:
foreach item if(a.contains(item) and !b.contains(item) || (!a.contains(item) and b.contains(item))) c.add(item)
或者这样做:
c.addAll(a); c.addAll(b); a.retainAll(b); //a now has the intersection of a and b c.removeAll(a);
请参阅设置文档和此页面.更多.
您可以使用具有方法intersection()union()和symmetricDifference()的Google-Collections Sets类.
Sets.intersection(set1, set2); Sets.union(set1, set2); SetView view = Sets.intersection(Sets.union(set1, set2), set3); Set result = view.copyInto(new HashSet());