diff options
Diffstat (limited to 'year2021/day5/part1.clj')
-rw-r--r-- | year2021/day5/part1.clj | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/year2021/day5/part1.clj b/year2021/day5/part1.clj new file mode 100644 index 0000000..95d04ba --- /dev/null +++ b/year2021/day5/part1.clj @@ -0,0 +1,75 @@ +(require '[clojure.string :as str]) + +(defn read-coords [] + (let [line (read-line)] + (when (not (empty? line)) + (mapv + #(Integer/parseInt %) + (str/split + line + #"[^\d]+" + ) + ) + ) + ) + ) + +(defn read-all-coords [] + (loop [cds [] c (read-coords)] + (if (empty? c) + cds + (recur + (conj cds c) + (read-coords) + ) + ) + ) + ) + +(defn mark-coord [cmap x y] + (update cmap y #(update % x inc)) + ) + +(defn mark-coords [cmap x1 y1 x2 y2] + (cond + (= y1 y2) + (reduce + #(mark-coord %1 %2 y1) + cmap + (range (min x1 x2) (inc (max x1 x2))) + ) + (= x1 x2) + (reduce + #(mark-coord %1 x1 %2) + cmap + (range (min y1 y2) (inc (max y1 y2))) + ) + :else + cmap + ) + ) + +(defn empty-map [] + (vec + (repeat 1000 + (vec (repeat 1000 0)) + ) + ) + ) + +(def finished-map + (reduce + #(apply (partial mark-coords %1) %2) + (empty-map) + (read-all-coords) + ) + ) + +(->> finished-map + (flatten) + (map dec) + (filter pos?) + (count) + (println) + ) + |