F# 如何基于谓词而不是固定长度对序列进行窗口化

标签 f#

给定以下输入序列,我想生成所需的输出。 我知道如果所有窗口都是固定长度,则可以使用 Seq.window 几乎获得所需的结果。然而在这种情况下,它们的长度不是固定的,我想每当遇到“a”时就开始一个新的序列。 标准集合库可以实现这一点吗?

let inputSequence = 
      ["a"; "b"; "c";
       "a"; "b"; "c"; "d";
       "a"; "b"; 
       "a"; "d"; "f";
       "a"; "x"; "y"; "z"]

let desiredResult = 
   [["a"; "b"; "c";]
    ["a"; "b"; "c"; "d";]
    ["a"; "b"; ]
    ["a"; "d"; "f";]
    ["a"; "x"; "y"; "z"]]

最佳答案

这是一种使用可变状态但非常简洁的方法:

let mutable i = 0
[ for x in inputSequence do
    if x = "a" then i <- i + 1
    yield i, x ]
|> List.groupBy fst
|> List.map snd
|> List.map (List.map snd)

关于F# 如何基于谓词而不是固定长度对序列进行窗口化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46389854/

相关文章:

python - 脚本语言选择

f# - cons::F# 中序列的运算符?

compilation - f# 我如何编译然后释放文件 .fsx

f# - 这个转置函数是如何工作的?

F# 的下划线 : why not just create a variable name?

F#:对复杂列表进行分组

f# - 在哪里可以找到 F# 模块 List 中 List.Map 的源代码?

list - 返回元组列表的第一个值

f# - FSharp 在基类中调用泛型方法

返回元组的函数的 F# 项目编译错误