Я скомпилировал эту программу и пытаюсь ее запустить.
import Data.List
import Data.Ord
import qualified Data.MemoCombinators as Memo
collatzLength :: Int -> Int
collatzLength = Memo.arrayRange (1, 1000000) collatzLength'
where
collatzLength' 1 = 1
collatzLength' n | odd n = 1 + collatzLength (3 * n + 1)
| even n = 1 + collatzLength (n `quot` 2)
main = print $ maximumBy (comparing fst) $ [(collatzLength n, n) | n <- [1..1000000]]
Я получаю следующее от GHC
Stack space overflow: current size 8388608 bytes.
Use `+RTS -Ksize -RTS' to increase it.
Я предполагаю, что это одна из вещей, "переполнение пространства", о которых я слышал. (Я довольно новичок в Haskell.) Как мне это исправить? Нужно ли переписывать collatzLength, чтобы хвост был рекурсивным?