我有以下代碼 -
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 屬性的類物件串列 - RefNo:即 List<SampleClass>
class SampleClass
{
public int RefNo {get;set;}
}
lst包含以下所有未排序的資料RefNo:
lst = 2,4,6,9,7,5,8,1,3
我想做的事 -
首先,我想lst通過將第一個元素保持為 -來訂購7;然后對于串列的其余部分,它應該作為陣列排序refNosToOrder
即我期望的最終輸出 -
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即此代碼根本沒有對串列進行排序。
uj5u.com熱心網友回復:
Contains回傳一個元素是否在串列中的布林值,這在這里不會很有幫助。相反,您可以按該元素的索引進行排序:
var orderedList =
lst.OrderBy(x => x.RefNo != 7)
.ThenBy(y => Array.IndexOf(refNosToOrder, y.RefNo))
.ToList();
編輯:
跟進 Jeroen Mostert 的評論,這種排序具有二次復雜性。對于大型refNosToOrder,首先將陣列轉換為訂單字典然后將其用于排序可能更有效:
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();
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/380491.html
上一篇:Log4j 漏洞測驗
