提问者:小点点

按数组元素排序Linq列表


我有下面的代码-

var refNosToOrder = new int[9] {1,2,3,4,5,6,7,8,9}

var orderedList = lst.OrderBy(x=>x.RefNo==7)
                     .ThenBy(y=> refNosToOrder.Contains(y.RefNo)).ToList();

lst是包含int属性的类对象列表-参考号:即list

class SampleClass
{
  public int RefNo {get;set;}
}

lst包含RefNo的所有未排序数据:

lst = 2,4,6,9,7,5,8,1,3

我想做什么-

首先,我想通过将第一个元素保持为-7来排序lst;然后对于列表的其余部分,它应该被排序为数组ereNosToOrder

i、 e.我期望的最终输出-

7,1,2,3,4,5,6,8,9

使用上述代码-

var orderedList = lst.OrderBy(x=>x.RefNo==7)
                         .ThenBy(y=> refNosToOrder.Contains(y.RefNo)).ToList();

它给-2,4,6,9,7,5,8,1,3,即这段代码根本没有排序列表。


共1个答案

匿名用户

包含返回元素是否在列表中的布尔值,这在这里没有太大帮助。相反,您可以根据该元素的索引进行排序:

var orderedList = 
    lst.OrderBy(x => x.RefNo != 7)
       .ThenBy(y => Array.IndexOf(refNosToOrder, y.RefNo))
       .ToList();

编辑:
继Jeroen Mostert的评论之后,这种排序具有二次复杂性。对于大型refnosoorder而言,首先将数组转换为订单字典,然后将其用于排序可能更有效:

var orderDict = 
    Enumerable.Range(0, refNosToOrder.Length).ToDictionary(i => refNosToOrder[i]);
var orderedList = 
    lst.OrderBy(x => x.RefNo != 7).ThenBy(y => orderDict[y.RefNo]).ToList();