26 lines
838 B
OCaml
26 lines
838 B
OCaml
(** [is_monotonic pred lst] returns true if [pred] returns true when tested on
|
|
all consecutive elements of [lst]. *)
|
|
let rec is_monotonic pred = function
|
|
| [] | _ :: [] -> true
|
|
| h :: h' :: t -> pred h h' && is_monotonic pred (h' :: t)
|
|
|
|
let is_safe lst =
|
|
(is_monotonic ( < ) lst || is_monotonic ( > ) lst)
|
|
&& is_monotonic (fun a b -> Aoc.distance1 a b <= 3) lst
|
|
|
|
let is_safe_dampened lst =
|
|
let rec impl acc = function
|
|
| [] -> is_safe acc
|
|
| h :: t -> is_safe (acc @ t) || impl (acc @ [ h ]) t
|
|
in
|
|
impl [] lst
|
|
|
|
let ints_of_file fname =
|
|
Aoc.strings_of_file fname |> List.map Aoc.ints_of_string
|
|
|
|
let day2402a lsts = List.filter is_safe lsts |> List.length
|
|
let day2402b lsts = List.filter is_safe_dampened lsts |> List.length
|
|
|
|
let _ =
|
|
Aoc.main ints_of_file [ (string_of_int, day2402a); (string_of_int, day2402b) ]
|