文書   >   Foundation   >   Collections   >   Set   >   reduce(_:_:)
汎用インスタンスメソッド
reduce(_:_:)
与えられたクロージャを使用してシーケンスの要素を組み合わせた結果を返します。
宣言
パラメータ
initialResult | 初期累積値として使用すべき値。クロージャが最初に実行されるときに、initialResult は nextPartialResult に渡されます。 |
nextPartialResult | nextPartialResult クロージャの次の呼び出しで使用される、または呼び出し元に返されるために、累積値とシーケンスの要素を新しい累積値に結合するクロージャ。 |
戻り値
最終的な累積値。シーケンスに要素がない場合、結果は initialResult です。
議論
シーケンス全体の要素から単一の値を生成するには、reduce(_:_:) メソッドを使用します。たとえば、このメソッドを数値の配列に使用して、それらの合計または積を見つけることができます。
nextPartialResult クロージャは、initialResult とシーケンスの各要素に初期化された累積値を使用して順次呼び出されます。この例は、数値の配列の合計を求める方法を示しています。
let numbers = [1, 2, 3, 4]
let numberSum = numbers.reduce(0, { x, y in
x + y
})
// numberSum == 10
numbers.reduce(_:_:) が呼び出されると、以下のステップが発生します。
- nextPartialResult クロージャは initialResult (この場合は 0) と numbers の最初の要素と共に呼び出され、合計 1 を返します。
- 前の呼び出しの戻り値とシーケンスの各要素を使用して、クロージャが繰り返し呼び出されます。
- シーケンスが使い果たされると、クロージャから返された最後の値が呼び出し元に返されます。
シーケンスに要素がない場合、nextPartialResult は決して実行されず、initialResult が reduce(_:_:) の呼び出しの結果になります。
複雑さ:O(n)、ここで n はシーケンスの長さです。
以下も見よ
Set の変形
func map<T>((Element) -> T) -> [T]
与えられたクロージャをシーケンスの要素にマッピングした結果を含む配列を返します。
func compactMap<ElementOfResult>((Element) -> ElementOfResult?) -> [ElementOfResult]
このシーケンスの各要素を使用して、与えられた変換を呼び出した結果の nil 以外の結果を含む配列を返します。
func flatMap<SegmentOfResult>((Element) -> SegmentOfResult) -> [SegmentOfResult.Element]
このシーケンスの各要素を使用して、与えられた変換を呼び出した結果を連結したものを含む配列を返します。
func flatMap<ElementOfResult>((Element) -> ElementOfResult?) -> [ElementOfResult]
  廃止  
func reduce<Result>(into: Result, (inout Result, Element) -> ()) -> Result
与えられたクロージャを使用してシーケンスの要素を組み合わせた結果を返します。
並べ替えられたシーケンスの要素を返します。
Element が Comparable に準拠している場合利用可能です。
func sorted(by: (Element, Element) -> Bool) -> [Element]
与えられた述語 (predicate) を要素間の比較として使用して、並べ替えられたシーケンスの要素を返します。
func shuffled() -> [Element]
シーケンスの要素をシャッフルして返します。
func shuffled<T>(using: inout T) -> [Element]
乱数の発生源として与えられた発生器を使用してシャッフルされた、シーケンスの要素を返します。
var lazy: LazySequence<Set<Element>>
このシーケンスと同じ要素を含むが、map や filter などの一部の操作が遅延的に実装されているシーケンス。
トップへ
トップへ
トップへ
トップへ
トップへ