diff options
author | J.J <thechairman@thechairman.info> | 2023-11-30 17:11:01 -0500 |
---|---|---|
committer | J.J <thechairman@thechairman.info> | 2023-11-30 17:11:01 -0500 |
commit | ced422119e4286a756b1f8346d1ac5bd8b1eea5f (patch) | |
tree | 9dd088ec9266a42f94e227992a367fd2641451a7 /aoc2021 | |
parent | f4051c5684bf75e1b343d94587676311ed245a75 (diff) | |
download | gleam_aoc-ced422119e4286a756b1f8346d1ac5bd8b1eea5f.tar.gz gleam_aoc-ced422119e4286a756b1f8346d1ac5bd8b1eea5f.zip |
prep for 2023
Diffstat (limited to 'aoc2021')
-rw-r--r-- | aoc2021/day-22/day-22.rkt | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/aoc2021/day-22/day-22.rkt b/aoc2021/day-22/day-22.rkt new file mode 100644 index 0000000..1dc4211 --- /dev/null +++ b/aoc2021/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) _)) + |