Project Euler – Problema 10
31 Agosto 2009
Riporto la soluzione al problema 10 in Haskell:
–Controlla se un numero è primo
isprime 2 = True
isprime t = if (filter (==0) (map (t`mod`)[2.. ceiling(sqrt (fromIntegral t))])==[]) then True else Falselistadeiprimi = [x|x<-[3, 5..2000000], isprime x]
listaprimi = 2 : listadeiprimi
result = sum listaprimi
Il programma non è ottimizzato: è stato fatto in un paio di minuti ed è molto migliorabile.
Il testo del problema:
The sum of the primes below 10 is 2 + 3 + 5 + 7 = 17.
Find the sum of all the primes below two million.