为了帮助我学习 Haskell,我正在解决 Project Euler 上的问题。解决每个问题后,我会对照 Haskell wiki 检查我的解决方案,以尝试学习更好的编码实践。这是问题3的解决方案:
primes = 2 : filter ((==1) . length . primeFactors) [3,5..]
primeFactors n = factor n primes
where
factor n (p:ps)
| p*p > n = [n]
| n `mod` p == 0 = p : factor (n `div` p) (p:ps)
| otherwise = factor n ps
problem_3 = last (primeFactors 317584931803)
我对此的幼稚阅读是primes
根据 定义,根据primeFactors
定义primes
。所以评估primeFactors 9
将遵循这个过程:
- 评估
factor 9 primes
。 - 求
primes
它的第一个元素,即 2。 - 询问
primes
它的下一个元素。 - 作为此过程的一部分,评估
primeFactors 3
. - 求
primes
它的第一个元素,即 2。 - 询问
primes
它的下一个元素。 - 作为此过程的一部分,评估
primeFactors 3
. - ...
换句话说,步骤 2-4 将无限重复。显然我错了,因为算法终止了。我在这里犯了什么错误?