我有一个名为技能的类,我通过一个参数接收到了它的列表,我需要通过LINQ创建一个包含一些规则的字符串列表。
我的班
public class Skill {
public int id {get;set;}
public int year {get;set;}
public int xp {get;set;}
}虚拟数据:
var skills = new List<Skill>(){
new Skill() { id=1, year = 9, xp = 95 } ,
new Skill() { id=2, year = 5 } ,
};规则: //年最多为10 // xp为最大100
我必须创建的字符串列表如下所示:直到每年10 + xp直到100 (如果有)
// '1-9-95'
// '1-9-96'
// '1-9-97'
// '1-9-98'
// '1-9-99'
// '1-9-99'
// '1-9-100'
// '1-10-95'
// '1-10-96'
// '1-10-97'
// '1-10-98'
// '1-10-99'
// '1-10-99'
// '1-10-100'
// '2-5'
// '2-6'
// '2-7'
// '2-8'
// '2-9'
// '2-10'我使用for语句获得了它,但我想知道是否使用LINQ。
发布于 2021-05-18 16:34:37
你需要SelectMany和Enumerable.Range
int maxYear = 10, maxXp = 100;
List<string> resultList = skills
.Where(skill => skill.year <= maxYear && skill.xp <= maxXp) // skip invalid
.SelectMany(skill => Enumerable.Range(skill.year, maxYear - skill.year + 1)
.SelectMany(y => Enumerable.Range(skill.xp, maxXp - skill.xp + 1)
.Select(xp => $"{skill.id}-{y}-{xp}")))
.ToList();.NET Fiddle:https://dotnetfiddle.net/c80wJs
我想我忽略了“(如果有)”,所以您只想在可用的情况下列出xp:
int maxYear = 10, maxXp = 100;
List<string> resultList = skills
.Where(skill => skill.year <= maxYear && skill.xp <= maxXp) // skip invalid
.SelectMany(skill => Enumerable.Range(skill.year, maxYear - skill.year + 1)
.SelectMany(y => Enumerable.Range(skill.xp, skill.xp == 0 ? 1 : maxXp - skill.xp + 1)
.Select(xp => skill.xp > 0 ? $"{skill.id}-{y}-{xp}" : $"{skill.id}-{y}")))
.ToList();..NET小提琴(感谢兰德随机):https://dotnetfiddle.net/06BIqg
https://stackoverflow.com/questions/67590239
复制相似问题