【发布时间】:2009-11-12 02:56:16
【问题描述】:
我想计算 Java 中任意数量的非空集的笛卡尔积。
我已经编写了那个迭代代码...
public static <T> List<Set<T>> cartesianProduct(List<Set<T>> list) {
List<Iterator<T>> iterators = new ArrayList<Iterator<T>>(list.size());
List<T> elements = new ArrayList<T>(list.size());
List<Set<T>> toRet = new ArrayList<Set<T>>();
for (int i = 0; i < list.size(); i++) {
iterators.add(list.get(i).iterator());
elements.add(iterators.get(i).next());
}
for (int j = 1; j >= 0;) {
toRet.add(Sets.newHashSet(elements));
for (j = iterators.size()-1; j >= 0 && !iterators.get(j).hasNext(); j--) {
iterators.set(j, list.get(j).iterator());
elements.set(j, iterators.get(j).next());
}
elements.set(Math.abs(j), iterators.get(Math.abs(j)).next());
}
return toRet;
}
...但我发现它相当不雅。 有人有更好的迭代解决方案吗?一个使用一些奇妙的函数式方法的解决方案? 否则......关于如何改进它的建议?错误?
【问题讨论】:
标签: java list algorithm set cartesian-product