查找具有不同相关性的所有条件



关于作业:有施法者(女巫(0)/仙女(1)),他们有魔法(int)。我把它们存储在一个列表中。

我要找到这两种类型的优点。(可以有多个施法者使用相同的法术能力)我写了这个代码,但是有一个问题。如果法力值最高的施法者是1,那么第一个FindAll将不会返回任何东西,因为它试图找到类型为0且法力值最高的施法者。如果综合法术能力最高的施法者是1型施法者,我怎么能得到一个包含最高法术能力的0型施法者的列表?

private List<Caster> BestCasters()
    {
        List<Caster> temp = new List<Caster>();
        temp = casters.FindAll(x => x.SpellPower == casters.Max(y => y.SpellPower) && (x.TypeOfCaster == 0));
        temp.AddRange(casters.FindAll(x => x.SpellPower == casters.Max(y => y.SpellPower) && (x.TypeOfCaster == 1))); 
        temp.OrderBy(x => x.TypeOfCaster).ThenBy(y => y.CasterName);
        return temp;
    }

LINQ GroupBy的行为是完美的:

var strongest_casters = casters.GroupBy(c => c.TypeOfCaster)
                               .Select(grp => grp.OrderByDescending(x => x.SpellPower)
                                                 .First()
                                      );

或返回每种类型的多个:

var strongest_casters = casters.GroupBy(c => c.TypeOfCaster)
                               .SelectMany(grp => grp.Where(y.SpellPower == grp.Max(x => x.SpellPower))
                                          );
private List<Caster> BestCasters()
{
    var witches = casters.Where(x => x.TypeOfCaster == 0).ToList();
    var fairies = casters.Where(x => x.TypeOfCaster == 1).ToList();
    int witchesMax = witches.Max(x => x.SpellPower);
    int fairiesMax = fairies.Max(x => x.SpellPower);
    var temp = witches.Where(x => x.SpellPower == witchesMax).ToList();
    temp.AddRange(fairies.Where(x => x.SpellPower == fairiesMax)); 
    return temp.OrderBy(x => x.TypeOfCaster).ThenBy(y => y.CasterName).ToList();
}

如果必须像这样使用FindAll,则应该在只包含正确类型的脚轮的子集上调用Max。当然,更合理的做法是先拆分初始列表,然后提取每种类型中最强的施法者。既然你没有告诉我你到底要做什么,我只能希望你被允许分开:-)

最新更新