在
Ruby中,Enumerable上有一个each_cons.它就是这样的
(1..5).each_cons(3) {|n| p n}
[1,2,3]
[2,3,4]
[3,4,5]
我想在C#中这样做. LINQ会很好.
下面做了类似的事情,但是它循环了一对多,并且它也被硬编码以仅返回两个元素
var ints = new int[] { 1,5,6,7 }; var cons = ints.Select((o,i) => new int[]{ ints[i],i == ints.Length - 1 ? 0 : ints[i + 1] });
如果它可以作为原始数组的迭代器创建而不必创建大量数组,那将是很好的.