aboutsummaryrefslogtreecommitdiff
path: root/racket/aoc2023/day-18/day-18.rkt
blob: b589e41121948ad930976ebee071051d9c908a9a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#lang racket
(require advent-of-code
         threading)

(struct coord (x y))

(define input (~> (fetch-aoc-input (find-session) 2023 18 #:cache #true)))

(define (go-to-next-coord c dir dist)
  (match-define (coord x y) c)
  (match dir
    [(or "R" "0") (coord (+ x dist) y)]
    [(or "D" "1") (coord x (- y dist))]
    [(or "L" "2") (coord (- x dist) y)]
    [(or "U" "3") (coord x (+ y dist))]))

(define/match (triangle-area _coord1 _coord2)
  [((coord x1 y1) (coord x2 y2)) (/ (- (* x1 y2) (* x2 y1)) 2)])

(define (find-area-using parser)
  (for/fold ([area 0]
             [perimeter 0]
             [current-coord (coord 0 0)]
             #:result (+ 1 (abs area) (/ perimeter 2)))
            ([dig (in-list (string-split input "\n"))])
    (define-values (dir dist) (parser dig))
    (define next-coord (go-to-next-coord current-coord dir dist))
    (values (+ area (triangle-area current-coord next-coord)) 
            (+ perimeter dist) next-coord)))

;; part 1
(define (parse-front dig)
  (match-define (regexp #rx"(.) (.*) \\((.*)\\)" 
                        (list _ dir (app string->number dist) _hex)) 
    dig)
  (values dir dist))

(find-area-using parse-front)

;; part 2

(define (parse-hex dig)
  (match-define (regexp #rx".*\\(#(.....)(.)\\)" 
                        (list _ (app (curryr string->number 16) dist) dir))
    dig)
  (values dir dist))

(find-area-using parse-hex)