博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于List<T>集合中的差集
阅读量:5994 次
发布时间:2019-06-20

本文共 2301 字,大约阅读时间需要 7 分钟。

差集在几何数学中的定义:一般地,记A,B是两个集合,则所有属于A且不属于B的元素构成的集合,叫做集合A减集合B(或集合A与集合B之差),类似地,对于集合A、B,我们把集合{x∣x∈A,且x∉B}叫做A与B的差集,记作A-B(或A\B),即A-B={x|x∈A且x∉ B}(或A\B={x|x∈A且x ∉B},同理 B-A={x∣x∈B且x∉A} 叫做B与A的差集

通俗点讲就是A-B 是属于A的但不属于B的那部分集合;

在.NET中 List<T>.Except()来实现集合的差集;

如:

List<string> A=new List(){"A","B","C"}    List<string> B=new List(){"C","D"}

 var m=  A.Except(B).ToList();

此时 m集合中的对象就是{"A","B"}

通过使用默认的相等比较器对值进行比较生成两个序列的差集。 (由 定义。)

通过使用指定的 对值进行比较产生两个序列的差集。

示例:

  public class PublishStock

     {
         public string EID { get; set; }

         

        //证券编码 
         public string SECURITYCODE { get; set; }
         //证券简称
        public string SECURITYSHORTNAME { get; set; } 

         //  市场缩写

         public string MARKETABR { get; set; }

         //市场编码

         public string MARKETCODE { get; set; }  

     }

    public class PublishStockComparer : IEqualityComparer<PublishStock>
    {

        public bool Equals(PublishStock x, PublishStock y)

        {
            //Check whether the compared objects reference the same data.
            if (Object.ReferenceEquals(x, y)) return true;

            //Check whether any of the compared objects is null.

            if (Object.ReferenceEquals(x, null) || Object.ReferenceEquals(y, null))
                return false;

            //Check whether the products' properties are equal.

            return x.SECURITYCODE == y.SECURITYCODE && x.MARKETCODE == y.MARKETCODE;
        }

        public int GetHashCode(PublishStock product)

        {
            //Check whether the object is null
            if (Object.ReferenceEquals(product, null)) return 0;

            //Get hash code for the Name field if it is not null.

            int hashProductName = product.SECURITYCODE == null ? 0 : product.SECURITYCODE.GetHashCode();

            //Get hash code for the Code field.

            int hashProductCode =product.MARKETCODE==null?0: product.MARKETCODE.GetHashCode()

           //Calculate the hash code for the product.

            return hashProductName ^ hashProductCode;
        }

注:当证券编码 ( SECURITYCODE)与 市场编码(MARKETCODE)相同时,表示对象相等;

调用:

PublishStock A=new PublishStock(){ EID="1",SECURITYCODE="001",SECURITYSHORTNAME="ZZ",MARKETCODE="100"}

PublishStock B=new PublishStock(){ EID="2",SECURITYCODE="002",SECURITYSHORTNAME="ZZ",MARKETCODE="300"}

PublishStock C=new PublishStock(){ EID="3",SECURITYCODE="001",SECURITYSHORTNAME="ZZ",MARKETCODE="100"}

List<PublishStock> Lst_A=new List<PublishStock>(){A,B};

List<PublishStock> Lst_B=new List<PublishStock>(){C};

var m=Lst_A.Except(Lst_B,new  PublishStockComparer()).ToList();

此时 m集合中的元素为{B};

 

 

转载于:https://www.cnblogs.com/h20064528/archive/2012/07/10/2584732.html

你可能感兴趣的文章
在Ubuntu14.4(32位)中配置I.MX6的QT编译环境
查看>>
BZOJ 3530: [Sdoi2014]数数 [AC自动机 数位DP]
查看>>
墨卡托投影、高斯-克吕格投影、UTM投影及我国分带方法
查看>>
Android中通过反射来设置Toast的显示时间
查看>>
Vysor Pro破解助手
查看>>
翻译Beginning iOS 7 Development中文版
查看>>
理顺FFT
查看>>
003-spring结合java类调用quartz
查看>>
Idea 常用功能汇总,工作中常用技巧,移出请说明原因,笔记花了好长时间汇总的...
查看>>
php给图片加入文字水印
查看>>
iOS开发-sqlite3使用
查看>>
(5)QlikView中的RowNo()函数
查看>>
SiteMesh2-示例工程
查看>>
poj 1087 A Plug for UNIX 【最大流】
查看>>
Phoenix与Squirrel 是什么?
查看>>
Photoshop制作的ico图标方法
查看>>
HDU 1241 Oil Deposits (DFS)
查看>>
【翻译自mos文章】注意: ASMB process exiting due to lack of ASM file activity
查看>>
Linux 线程浅析
查看>>
ucgui界面设计演示样例2
查看>>