C# 4.0。ラムダ式を使用して次のことを行うにはどうすればよいですか?
int[] a = new int[8] { 0, 1, 2, 3, 4, 5, 6, 7 };
// Now fetch every second element so that we get { 0, 2, 4, 6 }
int[] list = a.Where((value, index) => index % 2 == 0)
.ToArray();
%
(mod) operatorによって計算されるように、偶数のインデックスのみが選択されます。
5 % 2 // returns 1
4 % 2 // returns 0
MSDNによると:
を使用した別のアプローチEnumerable.Range
var result = Enumerable.Range(0, a.Length/2)
.Select(i => a[2*i])
.ToArray();
または、より効率的にチェックするためにビット単位を使用します。
var result = a.Where((i, index) => (index & 1) == 0)
.ToArray();
残りの演算子はあなたの友達です。
int[] everySecond = a.Where((i, ind) => ind % 2 == 0).ToArray();
%演算子は、最初のオペランドを2番目のオペランドで除算した後の余りを計算します。すべての数値タイプには、事前定義された剰余演算子があります。