Funzione List.scan<'T,'State> (F#)
Applica una funzione a ogni elemento della raccolta, eseguendo il threading di un argomento di accumulatore attraverso il calcolo.Questa funzione utilizza il secondo argomento e applica la funzione a questo e al primo elemento dell'elenco.Il risultato viene quindi passato alla funzione insieme al secondo elemento e così via.Infine, vengono restituiti l'elenco di risultati intermedi e il risultato finale.
Percorso di spazio dei nomi/modulo: Microsoft.FSharp.Collections.List
Assembly: FSharp.Core (in FSharp.Core.dll)
// Signature:
List.scan : ('State -> 'T -> 'State) -> 'State -> 'T list -> 'State list
// Usage:
List.scan folder state list
Parametri
folder
Tipo: 'State -> 'T -> 'StateFunzione da utilizzare per aggiornare lo stato in base agli elementi di input.
state
Tipo: 'StateStato iniziale.
list
Tipo: 'TlistElenco di input.
Valore restituito
Elenco di stati.
Note
Questa funzione è denominata Scan negli assembly compilati.Utilizzare questo nome se si accede alla funzione da un linguaggio .NET diverso da F# o tramite reflection.
Esempio
Nel codice riportato di seguito viene illustrato come utilizzare List.scan.
let initialBalance = 1122.73
let transactions = [ -100.00; +450.34; -62.34; -127.00; -13.50; -12.92 ]
let balances =
List.scan (fun balance transactionAmount -> balance + transactionAmount)
initialBalance transactions
printfn "Initial balance:\n $%10.2f" initialBalance
printfn "Transaction Balance"
for i in 0 .. List.length transactions - 1 do
printfn "$%10.2f $%10.2f" transactions.[i] balances.[i]
printfn "Final balance:\n $%10.2f" balances.[ List.length balances - 1]
Output
Piattaforme
Windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2
Informazioni sulla versione
Versioni della libreria di base F#
Supportato in: 2,0, 4,0, portabile