2

我有以下课程:

class Outer
{
   public ICollection<Inner> Inners
}

class Inner
{
    public ICollection<Inner> Inners
}

我想按其内部和嵌套内部的总数对外部列表进行降序排列。

例如:

如果我有 2 个外部:第一个有 3 个内部的集合,每个内部有 1 个嵌套内部,那么总数为 5。

第二个例如可以有 2 个内部的集合,每个内部有 3 个嵌套内部,那么总计数是 2 + 3 + 3 = 8

因此在返回的结果中,第二个例子应该是第一个。

任何人?:)

4

1 回答 1

3

首先,构建一个递归方法来计算对象内部的 Inner 对象,Inner包括它自己:

public static int Count(Inner inner)
{
    var count = 1;
    if (inner.Inners != null && inner.Inners.Any())
       count += inner.Inners.Sum(x => Count(x));

    return count;
}

然后您可以订购:

var result = outers.OrderBy(o => o.Inners.Sum(i => Count(i)));
于 2013-08-04T08:42:38.617 回答