Array.scan<'T,'State> Function (F#)
Like Array.fold, but returns the intermediate and final results.
Namespace/Module Path: Microsoft.FSharp.Collections.Array
Assembly: FSharp.Core (in FSharp.Core.dll)
// Signature:
Array.scan : ('State -> 'T -> 'State) -> 'State -> 'T [] -> 'State []
// Usage:
Array.scan folder state array
Parameters
folder
Type: 'State -> 'T -> 'StateThe function to update the state given the input elements.
state
Type: 'StateThe initial state.
array
Type: 'T []The input array.
Return Value
The array of state values.
Remarks
This function is named Scan in compiled assemblies. If you are accessing the function from a language other than F#, or through reflection, use this name.
Example
The following code illustrates the use of Array.scan.
let initialBalance = 1122.73
let transactions = [| -100.00; +450.34; -62.34; -127.00; -13.50; -12.92 |]
let balances =
Array.scan (fun balance transactionAmount -> balance + transactionAmount) initialBalance transactions
printfn "Initial balance:\n $%10.2f" initialBalance
printfn "Transaction Balance"
for i in 0 .. Array.length transactions - 1 do
printfn "$%10.2f $%10.2f" transactions.[i] balances.[i]
printfn "Final balance:\n $%10.2f" balances.[ Array.length balances - 1]
Output
Initial balance: $ 1122.73 Transaction Balance $ -100.00 $ 1122.73 $ 450.34 $ 1022.73 $ -62.34 $ 1473.07 $ -127.00 $ 1410.73 $ -13.50 $ 1283.73 $ -12.92 $ 1270.23 Final balance: $ 1257.31
Platforms
Windows 7, Windows Vista SP2, Windows XP SP3, Windows XP x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2
Version Information
F# Runtime
Supported in: 2.0, 4.0
Silverlight
Supported in: 3