diff options
author | HJ <thechairman@thechairman.info> | 2023-10-22 01:52:56 -0400 |
---|---|---|
committer | HJ <thechairman@thechairman.info> | 2023-10-22 01:52:56 -0400 |
commit | 796af82911a88b01ecf43fc90d03539007519917 (patch) | |
tree | 68003978e736201d7477845a3e33501e74e9e16f /2021 | |
parent | fafbeaf9e3c09ba7a5bea7e47d5736001f8a5aa1 (diff) | |
download | gleam_aoc-796af82911a88b01ecf43fc90d03539007519917.tar.gz gleam_aoc-796af82911a88b01ecf43fc90d03539007519917.zip |
2022 day 22
Diffstat (limited to '2021')
-rw-r--r-- | 2021/day-22/day-22.rkt | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/2021/day-22/day-22.rkt b/2021/day-22/day-22.rkt new file mode 100644 index 0000000..1dc4211 --- /dev/null +++ b/2021/day-22/day-22.rkt @@ -0,0 +1,32 @@ +#lang racket +(require "../../jj-aoc.rkt" + threading) + +(struct step (instruction xs ys zs) #:transparent) + +;; part 1 +(define (clamped-range nmin nmax) + (in-inclusive-range (max (string->number nmin) -50) + (min (string->number nmax) 50))) + +(define steps + (for/list ([l (in-list (~> (open-day 22 2021) (port->lines)))]) + (~>> l + (regexp-match #px"(.+) x=(-?\\d+)..(-?\\d+),y=(-?\\d+)..(-?\\d+),z=(-?\\d+)..(-?\\d+)") + rest + (match _ [(list direction xmin xmax ymin ymax zmin zmax) + (step (string->symbol direction) + (clamped-range xmin xmax) + (clamped-range ymin ymax) + (clamped-range zmin zmax))])))) + +(~> (for*/fold ([cubes (hash)]) + ([s (in-list steps)] + [to (in-value (step-instruction s))] + [x (step-xs s)] + [y (step-ys s)] + [z (step-zs s)]) + (hash-set cubes (list x y z) to)) + hash-values + (count (curry equal? 'on) _)) + |