使用 IEnumerable.Intersect() 有效率地找出 C# 中多個清單的交集
在資料分析和處理領域,尋找多個清單的交集是很常見的任務。雖然有多種方法可以解決這個問題,但使用 IEnumerable.Intersect() 方法可以提供一個高效率的解決方案。本文探討如何利用此方法來辨識和檢索多個清單的交集。
在 C# 中,當套用於多個序列時,IEnumerable.Intersect() 方法可用於取得所有序列中共同的元素。若要了解如何使用此方法尋找多個清單的交集,請考慮以下範例:
<code class="language-csharp">var list1 = new List<int>() { 1, 2, 3 }; var list2 = new List<int>() { 2, 3, 4 }; var list3 = new List<int>() { 3, 4, 5 }; var listOfLists = new List<List<int>>() { list1, list2, list3 }; // 预期交集为 List<int>() { 3 };</code>
要使用 IEnumerable.Intersect() 來找出這些清單的交集,我們可以利用以下方法:
<code class="language-csharp">var intersection = listOfLists .Skip(1) .Aggregate( new HashSet<int>(listOfLists.First()), (h, e) => { h.IntersectWith(e); return h; } );</code>
在此解決方案中,我們:
此解決方案提供了一種簡潔且有效率的方法,可以使用 IEnumerable.Intersect() 來尋找多個清單的交集。它利用 HashSet 的最佳化功能來處理重複元素並執行快速交集運算。
需要注意的是,listOfLists 應始終包含至少一個清單以初始化交集。如果清單為空,則會引發 ArgumentNullException。
以上是如何在 C# 中使用 IEnumerable.Intersect() 有效率地找出多個清單的交集?的詳細內容。更多資訊請關注PHP中文網其他相關文章!