文書   >   Swift   >   Dictionary   >   reduce(into:_:)
汎用インスタンスメソッド
reduce(into:_:)
与えられたクロージャを使用してシーケンスの要素を結合した結果を返します。
宣言
パラメータ
initialResult | 初期累積値として使用すべき値。 |
updateAccumulatingResult | 累積値をシーケンスの要素で更新するクロージャ。 |
戻り値
最終的な累積値。シーケンスに要素がない場合、結果は initialResult です。
議論
reduce(into:_:) メソッドを使用して、シーケンス全体の要素から単一の値を生成します。たとえば、整数の配列でこのメソッドを使用して、隣接する等しいエントリをフィルタリングしたり、頻度をカウントしたりできます。
このメソッドは、結果が Array や Dictionary などの書くときにコピーする型の場合、効率のために reduce(_:_:) よりも優先されます。
updateAccumulatingResult クロージャは、可変 (mutable) の累積値を initialResult およびシーケンスの各要素に初期化して、順次呼び出されます。この例は、文字列の文字の頻度の辞書を作成する方法を示しています。
let letters = "abracadabra"
let letterCount = letters.reduce(into: [:]) { counts, letter in
counts[letter, default: 0] += 1
}
// letterCount == ["a": 5, "b": 2, "r": 2, "c": 1, "d": 1]
letters.reduce(into:_:) が呼び出されると、以下の手順が発生します。
- updateAccumulatingResult クロージャは、最初の累積値 (この場合は [:]) と letters の最初の文字で呼び出され、キー "a" に 1 を設定して累積値を変更します。
- クロージャは、更新された累積値とシーケンスの各要素で再び繰り返し呼び出されます。
- シーケンスが使い果たされると、累積値が呼び出し元に返されます。
シーケンスに要素がない場合、updateAccumulatingResult は決して実行されず、initialResult が reduce(into:_:) の呼び出しの結果になります。
複雑さ:O(n)、ここで n はシーケンスの長さです。
以下も見よ
辞書の変換
func mapValues<T>((Value) -> T) -> Dictionary<Key, T>
与えられたクロージャによって変換された値を持つこの辞書のキーを含む新しい辞書を返します。
func reduce<Result>(Result, (Result, (key: Key, value: Value)) -> Result) -> Result
与えられたクロージャを使用してシーケンスの要素を結合した結果を返します。
func map<T>(((key: Key, value: Value)) -> T) -> [T]
与えられたクロージャをシーケンスの要素にマッピングした結果を含む配列を返します。
このシーケンスの各要素を使用して、与えられた変換を呼び出した結果の nil でない結果を含む配列を返します。
func compactMapValues<T>((Value) -> T?) -> Dictionary<Key, T>
与えられたクロージャによる変換の結果として、nil でない値を持つキー値のペアのみを含む新しい辞書を返します。
このシーケンスの各要素で与えられた変換を呼び出した連結結果を含む配列を返します。
  廃止  
要素間の比較として与えられた述語 (predicate) を使用して並べ替えられたシーケンスの要素を返します。
func shuffled() -> [(key: Key, value: Value)]
シャッフルされたシーケンスの要素を返します。
func shuffled<T>(using: inout T) -> [(key: Key, value: Value)]
乱数のソースとして与えられた発生器を使用してシャッフルされたシーケンスの要素を返します。
トップへ
トップへ
トップへ
トップへ
トップへ