aboutsummaryrefslogtreecommitdiff
path: root/haskell/004-largest_palindrome_product.hs
diff options
context:
space:
mode:
authorCharles <sircharlesaze@gmail.com>2019-08-11 22:36:40 +0200
committerCharles <sircharlesaze@gmail.com>2019-08-11 22:36:40 +0200
commit6b16d921543a62d880171791d39bcc58560785fa (patch)
treed47f5a23a52612107ddcc280c9bd128be7d1070f /haskell/004-largest_palindrome_product.hs
parent7b624de8e3e3637a07364f992c1d7e4185e4a872 (diff)
downloadproject_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.hs18
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]