Seq.cache 与 F# 中的 Seq.unfold
Seq.cache with Seq.unfold in F#
我正在尝试缓存三角形数字无限序列的结果。
let triCalc n = (n*(n+1))/2
let triNumC = 0 |> Seq.unfold (fun n -> Some((triCalc n, n+1))) |> Seq.cache
但是,当我尝试缓存时,它似乎并没有像我预期的那样工作
let x = Seq.take 4 (triNumC)
let y = Seq.take 4 (triNumC)
printf "%A" x
printf "%A" y
这会打印
seq [0; 1; 3; 6]seq [0; 1; 3; 6]
我缓存不正确吗?打印的第二个序列不应该是第一个序列的延续吗?我不太确定如何进步。
如果你想继续你需要跳过。顺序保持不变
let y = triNumC
|> Seq.skip 4
|> Seq.take 4
缓存没问题。缓存的好处是计算 y 是从第 5 项开始,因为前 4 项已经缓存。
我正在尝试缓存三角形数字无限序列的结果。
let triCalc n = (n*(n+1))/2
let triNumC = 0 |> Seq.unfold (fun n -> Some((triCalc n, n+1))) |> Seq.cache
但是,当我尝试缓存时,它似乎并没有像我预期的那样工作
let x = Seq.take 4 (triNumC)
let y = Seq.take 4 (triNumC)
printf "%A" x
printf "%A" y
这会打印
seq [0; 1; 3; 6]seq [0; 1; 3; 6]
我缓存不正确吗?打印的第二个序列不应该是第一个序列的延续吗?我不太确定如何进步。
如果你想继续你需要跳过。顺序保持不变
let y = triNumC
|> Seq.skip 4
|> Seq.take 4
缓存没问题。缓存的好处是计算 y 是从第 5 项开始,因为前 4 项已经缓存。