• [转][C#] 对List<T>取交集、连集及差集


    本文转自: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是否有交集
    
     
    
     1
    bool isIntersected = list1.Intersect(list2).Count() > 0
    2. 取差集 (A有,B沒有)
    
    List A : { 1 , 2 , 3 , 5 , 9 }
    
    List B : { 4 , 3 , 9 }
    
     1
    var expectedList = list1.Except(list2);
    結果 : { 1 , 2 , 5 }
    
     
    
    判斷A和B是否有差集
    
     
    
     1
    bool isExpected = list1.Expect(list2).Count() > 0
     
    
     
    
    3.  取聯集 (包含A和B)
    
    List A : { 1 , 2 , 3 , 5 , 9 }
    
    List B : { 4 , 3 , 9 }
    
     01
    public static class ListExtensions
    02
    {
    03
        public static List<T> Merge<T>(this List<T> source, List<T> target)
    04
        {
    05
            List<T> mergedList = new List<T>(source);
    06
     
    07
            mergedList.AddRange(target.Except(source));
    08
     
    09
            return mergedList;
    10
        }   
    11
    }
     
    
     
    
     1
    var mergedList = list1.Merge(list2);
    結果 : { 1 , 2 , 3 , 5 ,9 , 4 }
    
    ※ 6/15補充:感謝蹂躪大大提醒,LinQ已有內建方法Union可取聯集囉!
    
    結語
    
    使用Linq就可以輕鬆完成List的比對,
    
    如果有任何問題歡迎大家一起討論囉 :)

    最近在專案中,剛好遇到這個需求,

    需要比對兩個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是否有交集

     

    1 bool isIntersected = list1.Intersect(list2).Count() > 0

    2. 取差集 (A有,B沒有)

    List A : { 1 , 2 , 3 , 5 , 9 }

    List B : { 4 , 3 , 9 }

    1 var expectedList = list1.Except(list2);

    結果 : { 1 , 2 , 5 }

     

    判斷A和B是否有差集

     

    1 bool isExpected = list1.Expect(list2).Count() > 0

     

     

    3.  取聯集 (包含A和B)

    List A : { 1 , 2 , 3 , 5 , 9 }

    List B : { 4 , 3 , 9 }

    01 public static class ListExtensions
    02 {
    03     public static List<T> Merge<T>(this List<T> source, List<T> target)
    04     {
    05         List<T> mergedList = new List<T>(source);
    06  
    07         mergedList.AddRange(target.Except(source));
    08  
    09         return mergedList;
    10     }   
    11 }

     

     

    1 var mergedList = list1.Merge(list2);

    結果 : { 1 , 2 , 3 , 5 ,9 , 4 }

    ※ 6/15補充:感謝蹂躪大大提醒,LinQ已有內建方法Union可取聯集囉!

    結語


    使用Linq就可以輕鬆完成List的比對,

    如果有任何問題歡迎大家一起討論囉 :)

     
     
  • 相关阅读:
    2060: [Usaco2010 Nov]Visiting Cows 拜访奶牛
    2020: [Usaco2010 Jan]Buying Feed, II
    3396: [Usaco2009 Jan]Total flow 水流
    3403: [Usaco2009 Open]Cow Line 直线上的牛
    2102: [Usaco2010 Dec]The Trough Game
    最小生成树——Kruskal算法
    最短路径——Floyd算法(含证明)
    最短路径——Bellman-Ford算法以及SPFA算法
    最短路径——Dijkstra算法以及二叉堆优化(含证明)
    普通并查集
  • 原文地址:https://www.cnblogs.com/freeliver54/p/8031773.html
Copyright © 2020-2023  润新知