How can I determine if List A contains all of the elements from List B in the same order?
List A can have additional elements that List B does not have, but must co
Here's a quick way:
var equal = listA.Count - listB.Count < 0
? false
: Enumerable.Range(0, listA.Count - listB.Count).Any(i =>
listA.Skip(i).Take(listB.Count).SequenceEqual(listB));
However, I'd prefer to use an extension method like this:
public static bool ContainsSequence(this IEnumerable outer,
IEnumerable inner)
{
var innerCount = inner.Count();
for(int i = 0; i < outer.Count() - innerCount; i++)
{
if(outer.Skip(i).Take(innerCount).SequenceEqual(inner))
return true;
}
return false;
}
which you can call like:
var equals = listA.ContainsSequence(listB);
And here's a more efficient version of the same extension method specific to List:
public static bool ContainsSequence(this List outer, List inner)
{
var innerCount = inner.Count;
for (int i = 0; i < outer.Count - innerCount; i++)
{
bool isMatch = true;
for (int x = 0; x < innerCount; x++)
{
if (!outer[i + x].Equals(inner[x]))
{
isMatch = false;
break;
}
}
if (isMatch) return true;
}
return false;
}