Questo articolo è stato tradotto automaticamente. Per visualizzare l'articolo in inglese, selezionare la casella di controllo Inglese. È possibile anche visualizzare il testo inglese in una finestra popup posizionando il puntatore del mouse sopra il testo.
Traduzione
Inglese

Funzione List.fold<'T,'State> (F#)

Applica una funzione f a ogni elemento della raccolta, eseguendo il threading di un argomento dell'accumulatore attraverso il calcolo. La funzione fold utilizza il secondo argomento e applica la funzione f a questo e al primo elemento dell'elenco. Il risultato viene quindi passato alla funzione f insieme al secondo elemento e così via. Restituisce il risultato finale. Se la funzione di input è f e gli elementi sono i0...iN, tale funzione calcola f (... (f s i0) i1 ...) iN.

Percorso di spazio dei nomi/modulo: Microsoft.FSharp.Collections.List

Assembly: FSharp.Core (in FSharp.Core.dll)

// Signature:
List.fold : ('State -> 'T -> 'State) -> 'State -> 'T list -> 'State

// Usage:
List.fold folder state list

folder

Tipo: 'State -> 'T -> 'State

Funzione da utilizzare per aggiornare lo stato in base agli elementi di input.

state

Tipo: 'State

Stato iniziale.

list

Tipo: 'Tlist

Elenco di input.

Valore dello stato finale.

Questa funzione è denominata Fold negli assembly compilati. Utilizzare questo nome se si accede alla funzione da un linguaggio diverso da F# o tramite reflection.

Nell'esempio seguente viene illustrato l'utilizzo di List.fold


let data = [("Cats",4);
            ("Dogs",5);
            ("Mice",3);
            ("Elephants",2)]
let count = List.fold (fun acc (nm,x) -> acc+x) 0 data
printfn "Total number of animals: %d" count


            
              Numero totale di animali: 14
            
          

Nell'esempio di codice seguente vengono illustrati utilizzi aggiuntivi di List.fold. Si noti che esistono funzioni della libreria che incapsulano già la funzionalità implementata di seguito. Ad esempio, List.sum è disponibile per fare la somma di tutti gli elementi di un elenco.


let sumList list = List.fold (fun acc elem -> acc + elem) 0 list
printfn "Sum of the elements of list %A is %d." [ 1 .. 3 ] (sumList [ 1 .. 3 ])

// The following example computes the average of a list.
let averageList list = (List.fold (fun acc elem -> acc + float elem) 0.0 list / float list.Length)

// The following example computes the standard deviation of a list.
// The standard deviation is computed by taking the square root of the
// sum of the variances, which are the differences between each value
// and the average.
let stdDevList list =
    let avg = averageList list
    sqrt (List.fold (fun acc elem -> acc + (float elem - avg) ** 2.0 ) 0.0 list / float list.Length)

let testList listTest =
    printfn "List %A average: %f stddev: %f" listTest (averageList listTest) (stdDevList listTest)

testList [1; 1; 1]
testList [1; 2; 1]
testList [1; 2; 3]

// List.fold is the same as to List.iter when the accumulator is not used.
let printList list = List.fold (fun acc elem -> printfn "%A" elem) () list
printList [0.0; 1.0; 2.5; 5.1 ]

// The following example uses List.fold to reverse a list.
// The accumulator starts out as the empty list, and the function uses the cons operator
// to add each successive element to the head of the accumulator list, resulting in a
// reversed form of the list.
let reverseList list = List.fold (fun acc elem -> elem::acc) [] list
printfn "%A" (reverseList [1 .. 10])


Output

            
              La somma degli elementi dell'elenco [1; 2; 3] è 6.
            
            
              Elenco [1; 1; 1] media: stddev 1,000000: Elenco [0,000000 1; 2; 1] media: stddev 1,333333: Elenco [0,471405 1; 2; 3] medie: stddev 2,000000: 0,816497 0,0 1,0 2,5 5,1 [10; 9; 8; 7; 6; 5; 4; 3; 2; 1]
            
          

Windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2

Versioni della libreria di base F#

Supportato in: 2,0, 4,0, portabile

Aggiunte alla community

AGGIUNGI
Mostra: