diff options
| author | Mistivia <i@mistivia.com> | 2024-02-17 22:46:02 +0800 |
|---|---|---|
| committer | Mistivia <i@mistivia.com> | 2024-02-17 22:46:02 +0800 |
| commit | 3a4e5447a79096d813cdaf4498b9a1e2c086b7ff (patch) | |
| tree | 16c6d8452de6bbef3b38bc4f85b3d91300eb9e9f /advent-of-code/2022/02/2.rkt | |
| parent | 936a3523e268e621e7c754002c5aab61ac6dbb54 (diff) | |
aoc 2022 02
Diffstat (limited to 'advent-of-code/2022/02/2.rkt')
| -rw-r--r-- | advent-of-code/2022/02/2.rkt | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/advent-of-code/2022/02/2.rkt b/advent-of-code/2022/02/2.rkt new file mode 100644 index 0000000..4b0dd02 --- /dev/null +++ b/advent-of-code/2022/02/2.rkt @@ -0,0 +1,45 @@ +#lang racket + +(require "../../lib/utils.rkt") + +(define lines + (call-with-input-file "input" + (lambda (fp) (get-lines fp)))) + +(define games (map string-split lines)) + +(define (transform-cheat mine oppo) + (cond ((string=? "X" mine) (cond ((string=? "A" oppo) "Z") + ((string=? "B" oppo) "X") + ((string=? "C" oppo) "Y"))) + ((string=? "Y" mine) (cond ((string=? "A" oppo) "X") + ((string=? "B" oppo) "Y") + ((string=? "C" oppo) "Z"))) + ((string=? "Z" mine) (cond ((string=? "A" oppo) "Y") + ((string=? "B" oppo) "Z") + ((string=? "C" oppo) "X"))))) + +(set! games + (map + (lambda (x) + (list (car x) (transform-cheat (cadr x) (car x)))) + games)) + +(define (score game) + (define (base-score mine) + (cond ((string=? "X" mine) 1) + ((string=? "Y" mine) 2) + ((string=? "Z" mine) 3))) + (define (win-score mine oppo) + (cond ((string=? "X" mine) (cond ((string=? "A" oppo) 3) + ((string=? "B" oppo) 0) + ((string=? "C" oppo) 6))) + ((string=? "Y" mine) (cond ((string=? "A" oppo) 6) + ((string=? "B" oppo) 3) + ((string=? "C" oppo) 0))) + ((string=? "Z" mine) (cond ((string=? "A" oppo) 0) + ((string=? "B" oppo) 6) + ((string=? "C" oppo) 3))))) + (+ (base-score (cadr game)) (win-score (cadr game) (car game)))) + +(apply + (map score games))
\ No newline at end of file |
