diff options
| author | Charles <sircharlesaze@gmail.com> | 2019-08-11 22:36:40 +0200 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2019-08-11 22:36:40 +0200 |
| commit | 6b16d921543a62d880171791d39bcc58560785fa (patch) | |
| tree | d47f5a23a52612107ddcc280c9bd128be7d1070f /haskell/004-largest_palindrome_product.hs | |
| parent | 7b624de8e3e3637a07364f992c1d7e4185e4a872 (diff) | |
| download | project_euler-6b16d921543a62d880171791d39bcc58560785fa.tar.gz project_euler-6b16d921543a62d880171791d39bcc58560785fa.tar.bz2 project_euler-6b16d921543a62d880171791d39bcc58560785fa.zip | |
haskell problems 001 -> 006
Diffstat (limited to 'haskell/004-largest_palindrome_product.hs')
| -rw-r--r-- | haskell/004-largest_palindrome_product.hs | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/haskell/004-largest_palindrome_product.hs b/haskell/004-largest_palindrome_product.hs new file mode 100644 index 0000000..e0bd77d --- /dev/null +++ b/haskell/004-largest_palindrome_product.hs @@ -0,0 +1,18 @@ +-- Largest palindrome product + +-- Problem 4 +-- A palindromic number reads the same both ways. +-- The largest palindrome made from the product of two 2-digit numbers is 9009 = 91 × 99. + +-- Find the largest palindrome made from the product of two 3-digit numbers. + + +main = do + print (maximum [x * y | x <- [0..999], y <- [0..999], is_palindrome (x * y)]) + +is_palindrome :: Int -> Bool +is_palindrome x = all (\(y, z) -> y == z) $ zip (show x) (rev' $ show x) + +rev' :: [a] -> [a] +rev' [] = [] +rev' (x:xs) = (rev' xs) ++ [x] |
