1
下面的代码在某些情况下给我一个堆栈溢出错误(例如hosum (\x->x `mod` 3) 1000
),我不明白为什么。任何人都可以向我解释这个吗? (我是Haskell的新手,我很感激任何帮助:))haskell程序中的无限循环
hosum :: (Int -> Int) -> (Int -> Int)
hosum f = (\x -> hs f x (- x))
where hs :: (Int -> Int) -> Int -> Int -> Int
hs f 0 0 = f 0
hs f n m
| m <= n
= f m + hs f n (m+1)
| n <= m
= f n + hs f (n+1) m
| otherwise
= 0
好的,我明白了。非常感谢你:) –
我第二次删除'hs f 0 0'的情况。看起来很有趣,作为一个基本的例子,当每个递归调用中'n,m'增加_(增加1)。 – chi