我正在尝试使用C#MoreLinq来尝试找出重复项。
这是一个例子。联盟内部有一支球队。团队中的每个球员都可以打任何位置。
public sealed class Triad
{
public int Id1 {get;set;}
public int Id2 {get;set;}
public int Id3 {get;set;}
}
有了这个我想要GroupBy
ArrayOfTraids.GroupBy(new { Id1, Id2, Id3}).Select(t => t);
实施例
如果Id1 = 1,Id2 = 2且Id3 = 3,在本例中我们将得到1个对象。
我想解决的问题是,如果Id1 = 2,Id2 = 3,Id3 = 1,我希望它也可以分开同一个列表,因为int值仍然是1,2,3(不管是顺序,它们仍然是相同的值。)
我觉得这可能很简单,但我不确定。
解决
结束了这样的事情
ArrayOfTriads.Where(t => t.Id1 < t.Id2 && t.Id2 < t.Id3)
这消除了重复。闭合。
答案 0 :(得分:0)
你的回答:
ArrayOfTriads.Where(t => t.Id1 < t.Id2 && t.Id2 < t.Id3)
不适用于以下示例。它过滤掉前两个元素,而不是选择其中一个元素:
ArrayOfTraids.Add(new Triad(3, 2, 1));
ArrayOfTraids.Add(new Triad(2, 3, 1));
ArrayOfTraids.Add(new Triad(1, 2, 4));
ArrayOfTraids.Add(new Triad(1, 2, 5));
你得到:
Id1 Id2 Id3
1 2 4
1 2 5
我认为您可能希望按订购的ID进行分组。这是一种可行的方式:
ArrayOfTraids
.GroupBy(m => (string.Join(";", new List<int> { m.Id1, m.Id2, m.Id3 }
.OrderBy(n => n)))).Select(m => m.First());
这会产生:
Id1 Id2 Id3
3 2 1
1 2 4
1 2 5