List.Fold < T',' estado > Função (F#)
Aplica uma função f a cada elemento da coleção, threading um argumento acumulador através de computação. O fold função leva o segundo argumento e aplica a função f a ele e o primeiro elemento da lista. Em seguida, ela alimenta esse resultado a função f juntamente com o segundo elemento e assim por diante. Ele retorna o resultado final. Se a função de entrada for f e os elementos são i0...iN, em seguida, calcula a essa função f (... (f s i0) i1 ...) iN.
Caminho do namespace/módulo: Microsoft.FSharp.Collections.List
Assembly: FSharp.Core (em FSharp.Core.dll)
// Signature:
List.fold : ('State -> 'T -> 'State) -> 'State -> 'T list -> 'State
// Usage:
List.fold folder state list
Parâmetros
folder
Tipo: 'State -> 'T -> 'StateA função para atualizar o estado de elementos de entrada de dado.
state
Tipo: 'StateO estado inicial.
list
Tipo: 'T listaA lista de entrada.
Valor de retorno
O valor do estado final.
Comentários
Esta função é chamada de Fold em módulos (assemblies) compilados. Se você estiver acessando a função de um idioma diferente, por exemplo, F# ou através de reflexão, use esse nome.
Exemplo
O exemplo a seguir demonstra o uso deList.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
O exemplo de código a seguir ilustra os usos adicionais de List.fold. Observe que as funções de biblioteca existem que já encapsulam a funcionalidade implementada abaixo. Por exemplo, List.sum está disponível para somar todos os elementos de uma lista.
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])
Saída
Plataformas
O Windows 7, SP2 do Windows Vista, Windows XP SP3, Windows XP Professional x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2
Informações sobre versão
O tempo de execução F#
Compatível com: 2.0, 4.0
Silverlight
Compatível com: 3
Consulte também
Referência
Módulo de Collections.List (F#)
Microsoft.FSharp.Collections Namespace (F#)
Histórico de alterações
Date |
History |
Motivo |
---|---|---|
Maio de 2010 |
Exemplo de código adicionado. |
Aprimoramento de informações. |