栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java中任意集的笛卡尔积

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java中任意集的笛卡尔积

编辑:删除了两组的以前的解决方案。有关详细信息,请参见编辑历史记录。

这是一种对任意数量的集合进行递归处理的方法:

public static Set<Set<Object>> cartesianProduct(Set<?>... sets) {    if (sets.length < 2)        throw new IllegalArgumentException(     "Can't have a product of fewer than two sets (got " +     sets.length + ")");    return _cartesianProduct(0, sets);}private static Set<Set<Object>> _cartesianProduct(int index, Set<?>... sets) {    Set<Set<Object>> ret = new HashSet<Set<Object>>();    if (index == sets.length) {        ret.add(new HashSet<Object>());    } else {        for (Object obj : sets[index]) { for (Set<Object> set : _cartesianProduct(index+1, sets)) {     set.add(obj);     ret.add(set); }        }    }    return ret;}

请注意,不可能将任何通用类型信息与返回的集一起保留。如果你事先知道要使用多少个集合,则可以定义一个通用元组来容纳那么多元素(例如

Triple<A, B, C>
),但是在Java中无法拥有任意数量的通用参数。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/407663.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号