鉴于我有一个列表列表,其中所有列表都包含 0 个或多个项目,可能但不一定都是相同的数字。而且我希望有一个包含列表中所有项目的列表......但我希望顺序如下:首先是所有列表中的第一个项目,以便它们出现在“超级列表”中。List
<List<T>>
前任。
List[0] = { 'Apple', 'Blueberry', 'Cranberry' }
List[1] = { 'Anteater', 'Baboon', 'Camel', 'Dodo'}
List[2] = { 'Albatross', 'Blackbird', 'Chicken'}
result = { 'Apple', 'Anteater', 'Albatross', 'Blueberry', 'Baboon',
'Blackbird', 'Cranberry', 'Camel', 'Chicken', 'Dodo' }
(注意这不是字母顺序,蓝莓在狒狒之前)
当然,只要有一个不为空的列表,我就可以使用计数器循环遍历“超级列表”,将项目逐个添加到结果列表中:
int i = 0;
bool done = false;
while (!done)
{
bool found = false;
foreach (list l in superlist)
{
if (l.Count() > i)
{
found = true;
result.Add(l[i]);
}
}
i++;
if (!found)
done = true;
}
但是使用一些优化的 LINQ 函数来做到这一点会更好。我一直在研究Zip、GroupBy和Aggregate,但无法让它们工作。
那么:是否有一个漂亮的 LINQ 函数,或者多个函数的组合,可以将它变成漂亮的代码,或者我应该坚持(并且可能优化)我当前的函数?
编辑:一个简单的 SelectMany(x => x) 也不起作用,因为它保留了列表的顺序,而不是像我的算法那样折叠它们。有关更多详细信息,请参阅我最初的问题。