这是一个类似于[Get N max numbers from a List<int> using lambda expression]
的问题但是我想学习是否要保留那些N max数的索引,我应该如何使用lambda表达式来编写它。
示例)List<int> numbers = new List<int> { 12, 5, -8, 4, 7, 28, 3, 22 };
我们如何通过lambda获得4个最大数字:{28, 22, 12, 7}
加上索引{ 5, 7, 0, 4}
kirill建议:var result = numbers.OrderByDescending(n => n).Take(4);
但是如何获得N个最大数字的索引?它是一个双[,] 2D数组(不是列表)
答案 0 :(得分:3)
请注意:OrderBy + Take
是一个O(N * Log(N))操作,其中“Top N”可以更快地完成。 https://codereview.stackexchange.com/questions/9773/optimizing-liststring-performance-in-c/9777#9777
说;
List<int> numbers = new List<int>() { 12, 5, -8, 4, 7, 28, 3, 22 };
var list = numbers.Select((n, i) => new { Num=n, Inx=i })
.OrderByDescending(x => x.Num)
.Take(4)
.ToList();