关于作业:有施法者(女巫(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。当然,更合理的做法是先拆分初始列表,然后提取每种类型中最强的施法者。既然你没有告诉我你到底要做什么,我只能希望你被允许分开:-)