当前位置:  开发笔记 > 编程语言 > 正文

检查数组是否是另一个数组的子集

如何解决《检查数组是否是另一个数组的子集》经验,为你挑选了5个好方法。

有关如何检查该列表是否是另一个列表的任何想法?

具体来说,我有

List t1 = new List { 1, 3, 5 };
List t2 = new List { 1, 5 };

如何使用LINQ检查t2是否为t1的子集?



1> Cameron MacF..:
bool isSubset = !t2.Except(t1).Any();


但这对于具有重复值的列表不起作用

2> tvanfosson..:

如果使用集合,请使用HashSet而不是List.然后你可以简单地使用IsSubsetOf()

HashSet t1 = new HashSet{1,3,5};
HashSet t2 = new HashSet{1,5};

bool isSubset = t2.IsSubsetOf(t1);

对不起,它不使用LINQ.:-(

如果你需要使用列表,那么@Jared的解决方案可以解决你需要删除任何存在的重复元素的问题.


@JaredPar:那又怎样?向某人展示正确的方式比他们想要的方式更好吗?
究竟.您想要一个集合操作,使用为它们设计的类.Cameron的解决方案很有创意,但不像HashSet那样清晰/富有表现力.
嗯,我不同意,因为这个问题具体说"使用LINQ".

3> Géza..:

如果您是单元测试,您还可以使用CollectionAssert.IsSubsetOf方法:

CollectionAssert.IsSubsetOf(subset, superset);

在上述情况下,这意味着:

CollectionAssert.IsSubsetOf(t2, t1);



4> Neil..:

@ Cameron的解决方案作为扩展方法:

public static bool IsSubsetOf(this IEnumerable a, IEnumerable b)
{
    return !a.Except(b).Any();
}

用法:

bool isSubset = t2.IsSubsetOf(t1);

(这与@ Michael博客上发布的内容类似,但不完全相同)



5> user2325458..:

这是一个比这里发布的其他解决方案更有效的解决方案,尤其是顶级解决方案:

bool isSubset = t2.All(elem => t1.Contains(elem));

如果你能在t2中找到一个不在t1中的单个元素,那么你知道t2不是t1的子集.与使用.Except或.Intersect的解决方案不同,这种方法的优点是它可以在所有就地完成,而无需分配额外的空间.此外,该解决方案能够在找到违反子集条件的单个元素时立即中断,而其他元素继续搜索.下面是解决方案的最佳长形式,在我的测试中仅比上述速记解决方案略快.

bool isSubset = true;
foreach (var element in t2) {
    if (!t1.Contains(element)) {
        isSubset = false;
        break;
    }
}

我对所有解决方案进行了一些基本的性能分析,结果非常激烈.这两个解决方案比.Except()和.Intersect()解决方案快约100倍,并且不使用额外的内存.

推荐阅读
个性2402852463
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有