Если у меня есть IEnumerable, например:
string[] items = new string[] { "a", "b", "c", "d" };
Я хотел бы перебрать все пары последовательных элементов (скользящее окно размера 2). Что было бы
("a","b"), ("b", "c"), ("c", "d")
Мое решение было таково
public static IEnumerable<Pair<T, T>> Pairs(IEnumerable<T> enumerable) {
IEnumerator<T> e = enumerable.GetEnumerator(); e.MoveNext();
T current = e.Current;
while ( e.MoveNext() ) {
T next = e.Current;
yield return new Pair<T, T>(current, next);
current = next;
}
}
// used like this :
foreach (Pair<String,String> pair in IterTools<String>.Pairs(items)) {
System.Out.PrintLine("{0}, {1}", pair.First, pair.Second)
}
Когда я писал этот код, мне было интересно, есть ли уже функции в среде .NET, которые делают то же самое, и делают это не только для пар, но и для кортежей любого размера. ИМХО, должен быть хороший способ выполнять такие операции со скользящим окном.
Я использую C# 2.0 и могу себе представить, что в C# 3.0 (с LINQ) есть больше (и более приятных) способов сделать это, но меня в первую очередь интересуют решения C# 2.0. Хотя я также буду признателен за решения C# 3.0.
SmartEnumerator
Джона Скита, который сообщает вам, является ли элемент последним в списке. msmvps.com/blogs/jon_skeet/archive/2007/ 27/07/ - person Ben Voigt   schedule 02.08.2010