List<int> a = 1,2,3
List<int> b = 2,4,5
output
1,3,4,5
Найти непересекающийся набор данных с linq
Ответ 1
Трюк заключается в использовании За исключением с пересечением двух списков.
Это должно дать вам список непересекающихся элементов:
var nonIntersecting = a.Union(b).Except(a.Intersect(b));
Ответ 2
Пробовал и тестировал:
List<int> a = new List<int>(){1, 2, 3};
List<int> b = new List<int>(){2, 4, 5};
List<int> c = a.Except(b).Union(b.Except(a)).ToList();
Ответ 3
Другой способ:
List<int> a = new List<int> { 1, 2, 3 };
List<int> b = new List<int> { 2, 4, 5 };
var nonIntersecting = a.Union(b)
.Where(x => !a.Contains(x) || !b.Contains(x));