gpt4 book ai didi

haskell - STArray 和堆栈溢出

转载 作者:行者123 更新时间:2023-12-02 07:04:36 25 4
gpt4 key购买 nike

我很难理解为什么以下在 STArray 中查找最小元素的尝试在使用 ghc(7.4.1,无论 -O 级别如何)编译时会导致堆栈空间溢出,但是 ghci 中正常工作:

import Control.Monad
import Control.Monad.ST
import Control.Applicative
import Data.Array.ST

n = 1000 :: Int

minElem = runST $ do
arr <- newArray ((1,1),(n,n)) 0 :: ST s (STArray s (Int,Int) Int)
let ixs = [(i,j) | i <- [1..n], j <- [1..n]]
forM_ ixs $ \(i,j) -> writeArray arr (i,j) (i*j `mod` 7927)
-- readArray arr (34,56) -- this works OK
-- findMin1 arr -- stackoverflows when compiled
findMin2 arr -- stackoverflows when compiled

findMin1 arr = do
es <- getElems arr
return $ minimum es

findMin2 arr = do
e11 <- readArray arr (1,1)
foldM (\m ij -> min m <$> readArray arr ij) e11 ixs
where ixs = [(i,j) | i <- [1..n], j <- [1..n]]

main = print minElem

注意:切换到STUArrayST.Lazy 似乎没有任何效果。

但主要问题是:在 ST 内对大型 STArray 实现此类“类似折叠”操作的正确方法是什么?

最佳答案

这可能是 getElems 是个坏主意的结果。在这种情况下,数组完全不是一个好主意:

minimum (zipWith (\x y -> (x, y, mod (x*y) 7927)) [1..1000] [1..1000])

这个立即给你答案:(1, 1, 1)。

如果无论如何你都想使用数组,我建议先将数组转换为 ArrayUArray,然后再使用 elemsassocs 那个。如果您使用 runSTArrayrunSTUArray 执行此操作,则无需额外费用。

关于haskell - STArray 和堆栈溢出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14471359/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com