diff options
Diffstat (limited to 'day10/part2.clj')
-rw-r--r-- | day10/part2.clj | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/day10/part2.clj b/day10/part2.clj new file mode 100644 index 0000000..6cd27af --- /dev/null +++ b/day10/part2.clj @@ -0,0 +1,30 @@ +(def to-closing {\{ \} \( \) \[ \] \< \>}) +(def to-score {\) 1 \] 2 \} 3 \> 4}) + +(defn check-line [input] + (loop [open [] in input] + (cond + (empty? in) + (map to-closing open) + (and (contains? #{\} \) \] \>} (first in)) + (not= (to-closing (first open)) (first in))) + nil + :else + (recur + (if (contains? #{\{ \( \[ \<} (first in)) + (concat [(first in)] open) + (rest open)) + (rest in) + )))) + +(->> (slurp "./in") + (clojure.string/split-lines) + (mapv vec) + (mapv check-line) + (filter some?) + (mapv (partial reduce #(+ (* 5 %1) (to-score %2)) 0)) + (sort) + (#(get (vec %) (quot (count %) 2))) + (println) + ) + |