F# - 替换 For 循环的列表推导式
F# - List Comprehension To Replace For-Loop
我正在尝试用等效的列表理解替换现有的 for 循环,但我正在努力获得预期的结果。
module SOQN =
open System
open FSharp.Data
let main() =
let o = [| 5.00; 2.00; 3.00 |]
let p = [| 0.30; 0.50; 0.20 |]
let n = 3
let f = [| for x in o do
for y in p do
yield (x * y) - 1.0 |]
printfn "%A" <| f
// Expected Output: [| 0.50; 0.00; -0.40 |]
[<EntryPoint>]
main()
|> ignore
我想你想把数组“zip”在一起,像这样:
let f =
[| for (x, y) in Array.zip o p do
yield (x * y) - 1.0 |]
printfn "%A" <| f
当您有两个这样的 for
时,您将乘以两个数组,列出所有可能的组合。
使用Seq.map2
:
可以更轻松地达到你想要的效果
Seq.map2 (fun x y -> (x * y) - 1.0) o p |> Seq.toArray
我使用 Seq.map2
而不是 Array.map2
,因为如果两个数组的长度不同,数组版本会抛出异常。 Seq
版本在其中一个序列用完元素时停止。
我正在尝试用等效的列表理解替换现有的 for 循环,但我正在努力获得预期的结果。
module SOQN =
open System
open FSharp.Data
let main() =
let o = [| 5.00; 2.00; 3.00 |]
let p = [| 0.30; 0.50; 0.20 |]
let n = 3
let f = [| for x in o do
for y in p do
yield (x * y) - 1.0 |]
printfn "%A" <| f
// Expected Output: [| 0.50; 0.00; -0.40 |]
[<EntryPoint>]
main()
|> ignore
我想你想把数组“zip”在一起,像这样:
let f =
[| for (x, y) in Array.zip o p do
yield (x * y) - 1.0 |]
printfn "%A" <| f
当您有两个这样的 for
时,您将乘以两个数组,列出所有可能的组合。
使用Seq.map2
:
Seq.map2 (fun x y -> (x * y) - 1.0) o p |> Seq.toArray
我使用 Seq.map2
而不是 Array.map2
,因为如果两个数组的长度不同,数组版本会抛出异常。 Seq
版本在其中一个序列用完元素时停止。