I’m wondering if Linq has a method to check if two collections have at least a single element in common. I would expect something like this:
var listA = new List<int>() { some numbers };
var listB = new List<int>() { some numbers, potentially also in list A };
bool hasSameElements = listA.hasMatchingElements(listB);
Does it exists in Linq or should I write a custom method for it?
I am aware of the Intersect method, but doesn’t this yield the entire intersection set? I’m only interested in checking IF the two collection intersect, yielding the entire set seems like a waste, especially on larger collections.
Sounds like you just want:
EDIT: As noted in comments,
Intersectuses lazy evaluation. It defers all execution until the first element is read from the result; at that point it will load all oflistBinto a set, and then streamlistAuntil it finds a result to yield. At that point,Any()will returntrueand so no more work will be done. See my Edulinq post onIntersectfor more information.