Does anyone know how to make this Haskell code fun faster? I am doing Project Euler #14. This code runs in 4.029 seconds:
collatz :: Int -> Int64 -> Int
collatz c 1 = c
collatz c k
| even k = collatz (c+1) (k `div` 2)
| otherwise = collatz (c+1) (3*k + 1)
main = do
print $ maximum (map (\i -> (collatz 1 i, i)) [1..1000000])
Memoizing the collatz function actually increases the runtime, so I did not do any memoization. The comparable C code runs in 0.239 seconds:
int main(int argc, char *argv[])
{
int maxlength = 0;
int maxstart = 1;
for (int i = 1; i <= 1000000; i++) {
unsigned long k = i;
int length = 1;
while (k > 1) {
length += 1;
if (k % 2 == 0)
k = k / 2;
else
k = 3*k + 1;
}
if (length > maxlength) {
maxlength = length;
maxstart = i;
}
}
printf("%d, %d\n", maxlength, maxstart);
return 0;
}
The Haskell code is compiled with ghc -O3 and the C code is compiled with gcc -std=c99 -O3.