Skip to content

Instantly share code, notes, and snippets.

@dmalikov
Created December 31, 2011 00:00
Show Gist options
  • Save dmalikov/1542128 to your computer and use it in GitHub Desktop.
Save dmalikov/1542128 to your computer and use it in GitHub Desktop.
Project Euler 214 (190s)
import PECore (eulerTotient)
import Data.Numbers.Primes
import Control.Arrow ((&&&))
eulerChains :: Integer -> Integer
eulerChains 1 = 1
eulerChains n = 1 + eulerChains (eulerTotient n)
main = print . sum . map fst . filter ( (== 25) . snd ) . map ((&&&) id eulerChains) . takeWhile (<40000000) $ primes
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment