f# - Seq.groupBy 是否保留组内的顺序?

标签 f# sequences

我想对一个序列进行分组,然后获取组中每个元素第一次出现的位置。当我尝试这个时

Seq.groupBy f inSeq
|> Seq.map (fun (k,s) -> (k,s|>Seq.take 1|>Seq.exactlyOne))

我发现有时我会从 s 中得到不同的元素。这是预期的吗?

最佳答案

查看source of the groupBy implementation - 这是相关的部分:

// Build the groupings

seq |> iter (fun v ->
    let safeKey = keyf v
    let mutable prev = Unchecked.defaultof<_>
    match dict.TryGetValue (safeKey, &prev) with
    | true -> prev.Add v
    | false ->
        let prev = ResizeArray ()
        dict.[safeKey] <- prev
        prev.Add v)

它迭代源数组并将值添加到键的相应列表中。子序列的顺序直接受输入序列的顺序影响。对于相同的输入序列,我们可以期望groupBy返回相同的输出序列。这就是 groupBy 的测试编码方式。

如果您发现结果序列有变化,请检查输入序列。

关于f# - Seq.groupBy 是否保留组内的顺序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41384193/

相关文章:

f# - 在 .net 5 中运行 Forms 表单 F# 脚本?

python - 序列python中的插入算法

c# - 增长的、固定容量的通用序列的最佳选择

java - 如何在 Hibernate 中使用 Oracle 函数获取 ID

泛型:类型应该对另一种类型进行操作,而是对声明的文字值进行操作?

F#:按重复出现的元素序列分组

asynchronous - 使用 Async.Parallel 进行调度

f# - 如何在没有 "let rec"的情况下定义 y-combinator ?

python - 事后补充

mysql - 如何在 MySQL 中显示最常见的值序列?