比较集合内的集合



我有这样的集合:

Set<Set<Node>> NestedSet = new HashSet<Set<Node>>();
[[Node[0], Node[1], Node[2]], [Node[0], Node[2], Node[6]], [Node[3], Node[4], Node[5]]]

我想比较和合并嵌套集中的集。[0,1,2] 和 [0,2,6] 具有共同的元素。 所以应该将它们合并成 0,1,2,6。

输出应如下所示:

[[Node[0], Node[1], Node[2], Node[6]], [Node[3], Node[4], Node[5]]]

有没有有效的方法?

您可以使用 Collections.disjoint(Collection c1, Collection c2) 检查两个指定的集合是否具有共同的元素。

顺便说一句,请确保您的Node类实现了hashCodeequals

Set<Set<Node>> result = new HashSet<Set<Node>>();
for (Set<Node> s1 : NestedSet) {
    Optional<Set<Node>> findFirst = result.stream().filter(p -> !Collections.disjoint(s1, p)).findFirst();
    if (findFirst.isPresent()){
        findFirst.get().addAll(s1); 
    }
    else {
        result.add(s1);
    }
}

相关内容

  • 没有找到相关文章

最新更新