这是对 Project Euler 任务 #3 的剧透!如果您想自己解决,请不要继续阅读。
我正在尝试通过为 Project Euler 编写程序来学习 Haskell。目前我正在尝试解决任务#3,它要求数字 600851475143 的最大素数。
为此,我创建了一个liste
包含所有数字的列表,这些数字是这个数字的除数(直到它的平方根)。我现在的策略是,计算这些数字的除数,决定它们是否是素数。
number = 600851475143
-- sn = sqrt number
sn = 775146
liste = [x | x <- [1..sn], (mod number x == 0)]
-- liste = [1,71,839,1471,6857,59569,104441,486847]
primelist :: Int -> [Int]
primelist z = [y | y <- [1..z], mod z y == 0]
main = print [primelist x | x <- liste]
结果应该出现在这里,应该是一个包含 8 个列表的列表,其中包含 的元素的除数liste
。相反,列表
[[1],[1,3],[1,29],[1,3,29,87]]
被打印。
如何解释这种行为?