Подтвердить что ты не робот

Найти непересекающийся набор данных с linq

List<int> a = 1,2,3
List<int> b = 2,4,5

output
1,3,4,5
4b9b3361

Ответ 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));