Add 2025 day 25.

This commit is contained in:
2024-12-25 12:34:08 +00:00
parent 43b47b2a34
commit aea9724914
2 changed files with 38 additions and 2 deletions

34
bin/day2425.ml Normal file
View File

@@ -0,0 +1,34 @@
let pin_count = 5
let height = 7
let read_lock_or_key lst =
let result = Array.make pin_count 0 in
let add_node i c = if c = '#' then result.(i) <- result.(i) + 1 in
List.iter (String.iteri add_node) lst;
result |> Array.to_list
let locks_and_keys_of_list =
let rec impl locks keys = function
| [] -> (locks, keys)
| "" :: t -> impl locks keys t
| a :: b :: c :: d :: e :: f :: g :: t ->
let h = read_lock_or_key [ a; b; c; d; e; f; g ] in
if a = String.make pin_count '#' then impl locks (h :: keys) t
else impl (h :: locks) keys t
| _ -> failwith "locks_and_keys_of_list"
in
impl [] []
let locks_and_keys_of_file fname =
Aoc.strings_of_file fname |> locks_and_keys_of_list
let lock_key_fit lock key =
List.map2 ( + ) lock key |> List.for_all (( >= ) height)
let count_keys keys lock = List.filter (lock_key_fit lock) keys |> List.length
let count_locks_and_keys (locks, keys) =
List.map (count_keys keys) locks |> List.fold_left ( + ) 0
let _ =
Aoc.main locks_and_keys_of_file [ (string_of_int, count_locks_and_keys) ]

View File

@@ -23,7 +23,8 @@
day2421
day2422
day2423
day2424)
day2424
day2425)
(names
day2401
day2402
@@ -48,5 +49,6 @@
day2421
day2422
day2423
day2424)
day2424
day2425)
(libraries str aoc))