c# – LINQ中的高效列表自我比较?

这可能与此 question非常相似,但我想知道C#和LINQ中最有效的方法是在同一列表中比较元素列表.

例如,在伪代码中我想这样做:

foreach(i in list)    
    foreach(j in list.Except(i))    
        Compare(j,i)

我知道Except采用了一个可枚举而不是单个项目,可能不是最好的主意,但它应该说明我的意图.

有任何想法吗?

更新:

我想这个问题有点模糊.目标是迭代列表两次(使用LINQ),同时跳过对(i,i);无论比较(i,j)实际上做什么与我的问题无关.

那么有两种情况,一种是(i,j)==(j,i)和(i,j)!=(j,i).对于前者,乔治·达克特(George Duckett)在下面的跳过解决方案可以解决这个问题,但后者呢?这是我最初使用Except的地方,以便评估(i,j)和(j,i).

所以要澄清一下,除了list.Except(Enumerable.Repeat(i,1))之外,是否有更好的方法可以跳过列表中的元素?

解决方法

这将给你所有对,假设对的顺序无关紧要(比较(i,j)==比较(j,i)):
var test = from i in list
           from j in list.Skipwhile(j => j != i)
           where i != j // Remove the self-comparison if you want to
           select Compare(i,j);

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...