我很难找到一种有效但简单的方法来检查列表是否包含另一个列表(保留顺序)。它类似于 string.Contains(string) 功能。
假设我有四个整数集合:
A = [1, 2, 3, 4, 5]
B = [2, 3]
C = [5, 6, 7]
D = [3, 2, 4]
A.Contains(B)
会是真的,而A.Contains(C)
和A.Contains(D)
会是假的。
如果可以提供帮助,我宁愿不使用迭代器,但我无法想象一种有效的方法。以下代码效率极低。
public static bool IsSequentiallyEqual<T>(this IEnumerable<T> lhs, IEnumerable<T> rhs)
{
return lhs.Zip(rhs, (a, b) => a.Equals(b)).All(isEqual => isEqual == true);
}
public static bool StartsWith<T>(this IEnumerable<T> haystack, IEnumerable<T> needle)
{
return haystack.Take(needle.Count()).IsSequentiallyEqual(needle);
}
public static bool Contains<T>(this IEnumerable<T> haystack, IEnumerable<T> needle)
{
var result = list.SkipWhile((ele, index) => haystack.Skip(index).StartsWith(needle));
return result.Count() >= needle.Count();
}