删除了两个集合的先前解决方案。有关详细信息,请参阅编辑历史记录。
这里有一种方法可以递归地对任意数量的集合执行此操作:public static Set> cartesianProduct(Set>... sets) {
if (sets.length
throw new IllegalArgumentException(
"Can't have a product of fewer than two sets (got " +
sets.length + ")");
return _cartesianProduct(0, sets);}private static Set> _cartesianProduct(int index, Set>... sets) {
Set> ret = new HashSet>();
if (index == sets.length) {
ret.add(new HashSet());
} else {
for (Object obj : sets[index]) {
for (Set set : _cartesianProduct(index+1, sets)) {
set.add(obj);
ret.add(set);
}
}
}
return ret;}
请注意,不可能在返回的集合中保留任何泛型类型信息。如果事先知道您想要的产品有多少集,则可以定义一个泛型元组来保存这些元素(例如Triple),但是在Java中不可能有任意数量的泛型参数。