F# - 替换 For 循环的列表理解

问题描述

我正在尝试用等效的列表理解替换现有的 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

解决方法

当您有两个这样的 for 时,您会将两个数组相乘,列出所有可能的组合。

您可以使用 Seq.map2 更轻松地实现您想要的:

Seq.map2 (fun x y -> (x * y) - 1.0) o p |> Seq.toArray

我使用 Seq.map2 而不是 Array.map2 因为如果两个数组的长度不同,数组版本会抛出异常。 Seq 版本会在其中一个序列用完元素时停止。

,

我认为您想将数组“zip”放在一起,如下所示:

let f =
    [| for (x,y) in Array.zip o p do
        yield (x * y) - 1.0 |]

printfn "%A" <| f

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...