This commit is contained in:
Jens Kadenbach
2022-12-01 15:57:27 +01:00
commit c104561d8b
16 changed files with 2670 additions and 0 deletions

39
src/Day1.hs Normal file
View File

@@ -0,0 +1,39 @@
module Day1 (
day1,
findElfWithHighestCalorieCount,
findCaloriesOfTop3Elves
) where
import qualified Data.Text as T
import Day1.Internal
day1 :: IO ()
day1 = do
putStrLn "Day1"
calorieCount <- day1_1
putStrLn ("Highest calorie count = " ++ calorieCount)
caloriesOfTop3Elves <- day1_2
putStrLn ("Calories of top 3 elves = " ++ caloriesOfTop3Elves)
putStrLn "-----------"
day1_1 :: IO String
day1_1 = do
input <- readFile "ressources/day01-input"
return (show $ findElfWithHighestCalorieCount $ T.pack input)
day1_2 :: IO String
day1_2 = do
input <- readFile "ressources/day01-input"
return (show $ findCaloriesOfTop3Elves $ T.pack input)
findCaloriesOfTop3Elves :: T.Text -> CalorieCount
findCaloriesOfTop3Elves =
calories . sumCalories . take 3 . sortElves . elfToCalories
where
sumCalories :: [Elf] -> Int
sumCalories = sum . map caloriesOf
findElfWithHighestCalorieCount :: T.Text -> Elf
findElfWithHighestCalorieCount = head .sortElves . elfToCalories