Haskell和Functional的新版本
在Haskell (ghci)中,scanl在下列表达式中做了什么?
scanl (+) 0 [1,3..]scanl (*) 1 [1..]一开始,我认为它列出了一个无穷大的奇数列表,然后依次添加它们,但是这听起来不对。这两种表达方式都是干什么用的?
谢谢
发布于 2020-10-31 19:59:40
scanl和foldl一样,只是给出了一个中间结果列表,而不仅仅是最后一个结果。理解它有助于理解foldl,反之亦然。例如,当foldl (+) 0查找列表中所有元素的和时,scanl (+) 0向您显示导致它的所有中间和:
ghci> scanl (+) 0 [1,1,1,2,5]
[0, 1, 2, 3, 5, 10]
-- +1 +1 +1 +2 +5类似地,由于foldl (++) ""连接了一串搅拌器,所以scanl (++) ""向您展示了中间连接:
ghci> scanl (++) "" ["foo", "bar", "baz", "quux"]
["", "foo", "foobar", "foobarbaz", "foobarbazquux"]https://stackoverflow.com/questions/64624131
复制相似问题