【问题标题】:reduce a list of functions to a boolean将函数列表简化为布尔值
【发布时间】:2012-05-13 06:26:45
【问题描述】:

我正在寻找一种方法来将此列表简化为布尔值。这是原文:

let ones = [1;1;1;1]
let twos = [2;2;2;2]
let bad = [1;2;3]

let isAllOnes = List.forall (fun op -> op = 1)
let isAllTwos = List.forall (fun op -> op = 2)  

let isOneOrTwo ops = isAllOnes ops || isAllTwos ops

isOneOrTwo ones |> should be True
isOneOrTwo twos |> should be True
isOneOrTwo bad |> should be False

我正在尝试使用一种 reduce 来重构它。像这样的:

let isOneOrTwo ops = [isAllOnes; isAllTwos] |> List.tryFind (fun acc -> acc ops) 

(isOneOrTwo ones).IsSome |> should be True
(isOneOrTwo twos).IsSome |> should be True
(isOneOrTwo bad).IsSome |> should be False

我不喜欢 isOneOrTwo 如何简化为选项。我真的很想将列表简化为布尔值,以便我的断言看起来像这样:

isOneOrTwo ones |> should be True
isOneOrTwo twos |> should be True
isOneOrTwo bad |> should be False

有人知道如何实现吗? List.reduce 不起作用,因为类型不同。

【问题讨论】:

    标签: f# mapreduce reduce


    【解决方案1】:

    将 List.tryFind 替换为 List.exists

    let ones = [1;1;1;1]
    let twos = [2;2;2;2]
    let bad = [1;2;3]
    
    let allOnes = List.forall ((=) 1)
    let allTwos = List.forall ((=) 2)
    
    let isOneOrTwo l = [allOnes; allTwos] |> List.exists (fun f -> f l)
    
    printfn "%A " (isOneOrTwo ones) // true
    printfn "%A " (isOneOrTwo twos) // true
    printfn "%A " (isOneOrTwo bad)  // false
    

    【讨论】:

    • 哇,我喜欢这样一个干净简单的解决方案。
    猜你喜欢
    • 2016-08-27
    • 1970-01-01
    • 2018-09-01
    • 1970-01-01
    • 2020-02-10
    • 2013-09-15
    • 2014-01-30
    • 1970-01-01
    • 2013-02-07
    相关资源
    最近更新 更多