Add Haskell solution for Problem 22
This commit is contained in:
parent
7a67ad0659
commit
5453c1d2c8
22
Haskell/p022.hs
Normal file
22
Haskell/p022.hs
Normal file
@ -0,0 +1,22 @@
|
||||
-- Using p022_names.txt, a 46K text file containing over five-thousand first names, begin by sorting it into alphabetical order.
|
||||
-- Then working out the alphabetical value for each name, multiply this value by its alphabetical position in the list to obtain a name score.
|
||||
--
|
||||
-- For example, when the list is sorted into alphabetical order, COLIN, which is worth 3 + 15 + 12 + 9 + 14 = 53, is the 938th name in the list.
|
||||
-- So, COLIN would obtain a score of 938 × 53 = 49714.
|
||||
--
|
||||
-- What is the total of all the name scores in the file?
|
||||
|
||||
import Data.Char (ord)
|
||||
import Data.List (sort)
|
||||
import Data.List.Split (splitOn)
|
||||
|
||||
nameScore :: String -> Int
|
||||
nameScore s = let a = ord 'A' - 1
|
||||
in sum $ map ((\x -> x - a) . ord) s
|
||||
|
||||
main = do
|
||||
contents <- readFile "p022_names.txt"
|
||||
let name_scores = map nameScore . sort . splitOn "," $ filter (/= '"') contents
|
||||
result = sum $ zipWith (*) name_scores [1..]
|
||||
putStrLn $ "Project Euler, Problem 22\n"
|
||||
++ "Answer: " ++ show result
|
1
Haskell/p022_names.txt
Normal file
1
Haskell/p022_names.txt
Normal file
File diff suppressed because one or more lines are too long
Loading…
x
Reference in New Issue
Block a user