Противоположность set(a) & set(b) & set(c)
уже объяснена в этом вопросе , как указано Chris_Rands в комментариях:
>>> (set(a) | set(b) | set(c)) - (set(a) & set(b) & set(c))
{1, 2, 5, 6}
Для действительно длинных списков, используяNumpy должен быть эффективным:
import numpy as np
from functools import reduce
a = [1, 2, 3, 4]
b = [2, 3, 4, 5]
c = [3, 4, 5, 6]
union = reduce(numpy.union1d, (a,b,c))
intersect = reduce(numpy.intersect1d, (a,b,c))
print(numpy.setdiff1d(union, intersect))
Вывод:
[1 2 5 6]