
List<int[]> a = new List<int[]>(){ new int[]{3,4,5},new int[]{7,8,9},new int[]{10,11,12} };List<int[]> b = new List<int[]>(){ new int[]{6,7,new int[]{3,41,12} };var c = a.Except(b); 并且考虑{3,5}不存在可枚举的c?当然我试过了,这个没用.有没有像Except一样高效的解决方案?或者甚至更好,更快?
解决方法 在.NET中,如果数组是完全相同的数组对象,则它们只等于另一个数组.因此,具有相同内容的两个不同阵列不被视为相等:int[] x = new int[] { 1,2 };int[] y = new int[] { 1,2 };Console.Writeline(x == y); // false 为了根据内容检查相等性,可以使用Enumerable.SequenceEqual:
Console.Writeline(x.SequenceEqual(y)); // true
当然,在尝试使用Enumerable.Except时,这对您没有直接帮助,因为默认情况下将使用默认的相等比较器,它仅检查相等性(并且因为每个数组都不等于除了它自己之外的所有其他数组…).
因此,解决方案将是use the other overload,并提供自定义IEqualityComparer,根据其内容比较阵列.
public class IntArrayEqualityComparer : IEqualityComparer<int[]>{ public bool Equals(int[] a,int[] b) { return a.SequenceEqual(b); } public int GetHashCode(int[] a) { return a.Sum(); }} 不幸的是,仅仅委托给SequenceEqual是不够的.我们还必须为此提供GetHashCode实现.作为一个简单的解决方案,我们可以在这里使用数组中的数字之和.通常,我们希望提供一个强大的哈希函数,它告诉了很多内容,但由于我们只使用这个哈希函数进行Except调用,我们可以在这里使用一些简单的东西. (通常,我们还希望避免从可变对象创建哈希值)
使用该相等比较器时,我们正确地过滤掉了重复的数组:
var c = a.Except(b,new IntArrayEqualityComparer());总结
以上是内存溢出为你收集整理的c# – 使用Linq除了两个int数组列表全部内容,希望文章能够帮你解决c# – 使用Linq除了两个int数组列表所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)