diff options
author | J.J <thechairman@thechairman.info> | 2023-11-30 17:10:00 -0500 |
---|---|---|
committer | J.J <thechairman@thechairman.info> | 2023-11-30 17:10:00 -0500 |
commit | 8ab65dc2da1742eb86ec636c50c7018385b68167 (patch) | |
tree | c4fd556aca9b867cfa1f2f174128c30857353884 /aoc2020/day-07 | |
parent | fafbeaf9e3c09ba7a5bea7e47d5736001f8a5aa1 (diff) | |
download | gleam_aoc-8ab65dc2da1742eb86ec636c50c7018385b68167.tar.gz gleam_aoc-8ab65dc2da1742eb86ec636c50c7018385b68167.zip |
prep for 2023, renaming for consistency
Diffstat (limited to 'aoc2020/day-07')
-rw-r--r-- | aoc2020/day-07/day-07.rkt | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/aoc2020/day-07/day-07.rkt b/aoc2020/day-07/day-07.rkt new file mode 100644 index 0000000..f2a1ffe --- /dev/null +++ b/aoc2020/day-07/day-07.rkt @@ -0,0 +1,46 @@ +#lang racket +(require advent-of-code + threading + rebellion/collection/entry + rebellion/collection/multidict) + +(define raw-rules (~> (open-aoc-input (find-session) 2020 7) (port->string) (string-split "\n"))) + +(define (split-rule r) + (match-define (list head tail) (string-split (string-trim r #px" bags?.") " bags contain ")) + (~>> tail + (regexp-split #px"( bags?,\\s)" _) + (map (λ~> (regexp-match* #px"(\\d+) (\\w+ \\w+)" _ #:match-select rest))) + append* + (map (λ~> (match _ + [(list n c) (list (string->symbol c) (string->number n))] + ['() '()]))) + (cons (string->symbol head) _))) + +(define rules-multidict + (for*/multidict ([ln (in-list raw-rules)] #:do [(match-define (list* from tos) (split-rule ln))] + [to (in-list tos)]) + (entry from to))) + +;; part 1 +(define (bags-that-eventually-contain target) + (for/fold ([holders (set)]) ([rule (in-multidict-entries rules-multidict)]) + (match rule + [(entry outside (list (== target) _)) + (set-union (set-add holders outside) (bags-that-eventually-contain outside))] + [_ holders]))) + +(define part-1 (set-count (bags-that-eventually-contain '|shiny gold|))) +(~a "Part 1: " part-1) +;; (aoc-submit (find-session) 2020 7 1 part-1) + +;; part 2 +(define (bags-that-are-contained-by target) + (for/sum ([holding (in-multidict-entries rules-multidict)]) + (match holding + [(entry (== target) (list held n)) (+ n (* n (bags-that-are-contained-by held)))] + [_ 0]))) + +(define part-2 (bags-that-are-contained-by '|shiny gold|)) +(~a "Part 2: " part-2) +;; (aoc-submit (find-session) 2020 7 1 part-2) |