使用LINQ确定该序列包含其他序列,顺序相同

Ami*_*ion 5 c# linq

样品:

a)1,2,3,4,5

b)2,3,4

a包含b.

不像.Intersect(),我需要保持序列顺序,即:

c)4,3,2

a不包含c.

Maa*_*ten 3

如果您正在谈论内存中的集合,其中比较很简单,您可以使用类似的东西(但要注意,集合会迭代多次!):

public static bool Contains<T>(this IEnumerable<T> data, IEnumerable<T> otherData) {
    var dataLength = data.Count();
    var otherDataLength = otherData.Count();

    if (dataLength < otherDataLength)
        return false;

    return Enumerable.Range(0, dataLength - otherDataLength + 1)
        .Any(skip => data.Skip(skip).Take(otherDataLength).SequenceEqual(otherData));
}
Run Code Online (Sandbox Code Playgroud)

并像这样使用它:

var a1 = new List<int> { 1, 2, 3, 4, 5 };
var a2 = new List<int> { 2, 3, 4};
var a3 = new List<int> { 4, 3, 2};

if (a1.Contains(a2)) {
    // is hit
}

if (a1.Contains(a3)) {
    // is not hit
}
Run Code Online (Sandbox Code Playgroud)