标签:
转载于:http://www.cnblogs.com/shuibin/archive/2012/04/19/2457867.html
最近在项目中,刚好遇到这个需求,
需要比较两个List,进行一些交集等操作,
在以前我们可能需要写很多行來完成這些动作,
但现在我们只需要借由LinQ就能轻松达到目的!
※本文使用int为例,若为使用自定之DataModel,需實作IEquatable<T>介面才能使用
1. 取交集 (A和B都有)
List A : { 1 , 2 , 3 , 5 , 9 }
List B : { 4 , 3 , 9 }
1 var intersectedList = list1.Intersect(list2);
結果 : { 3 , 9 }
判断A和B是否有交集
bool isIntersected = list1.Intersect(list2).Count() > 0
2. 取差集 (A有,B沒有)
List A : { 1 , 2 , 3 , 5 , 9 }
List B : { 4 , 3 , 9 }
var expectedList = list1.Except(list2);
結果 : { 1 , 2 , 5 }
判断A和B是否有差集
bool isExpected = list1.Expect(list2).Count() > 0
3. 取并集(包含A和B)
List A : { 1 , 2 , 3 , 5 , 9 }
List B : { 4 , 3 , 9 }
public static class ListExtensions { public static List<T> Merge<T>(this List<T> source, List<T> target) { List<T> mergedList = new List<T>(source); mergedList.AddRange(target.Except(source)); return mergedList; } } var mergedList = list1.Merge(list2);
結果 : { 1 , 2 , 3 , 5 ,9 , 4 }
使用Linq就可以轻松完成List的比对,
如果有任何问题欢迎大家一起讨论
转载于:http://www.cnblogs.com/liguanghui/archive/2011/11/09/2242309.html
首先举例2个集合A,B.
List<int> listA = new List<int> {1,2,3,5,7,9};
listA.BinarySearch("1");//判断集合中是否包含某个值.如果包含则返回0
在举例两个数组
r.AddRange(i);
int[] c = r.ToArray(); 合并数组
int[] x=i.Union(j).ToArray<int>(); //剔除重复项
int[] x=i.Concat(j).ToArray<int>(); //保留重复项
int n = Array.BinarySearch(i,3);//判断数组中是否包含某个值.如果包含则返回0
标签:
原文地址:http://www.cnblogs.com/wslm/p/4354292.html