我正在尝试编写一个简单的筛函数来计算Clojure中的素数。我已经看到了这个关于编写高效的筛分功能的问题,但我不是为了那点呢。现在,我只是想编写一个非常简单(且缓慢)的筛子。这是我想出的:
(defn sieve [potentials primes]
(if-let [p (first potentials)]
(recur (filter #(not= (mod % p) 0) potentials) (conj primes p))
primes))
对于小范围,它可以正常工作,但会导致大范围的堆栈溢出:
user=> (sieve (range 2 30) [])
[2 3 5 7 11 13 17 19 23 29]
user=> (sieve (range 2 15000) [])
java.lang.StackOverflowError (NO_SOURCE_FILE:0)
我以为通过使用recur它将是一个不消耗堆栈的循环结构?我想念什么?
www说