aboutsummaryrefslogtreecommitdiffstats
path: root/year2021/day5/part1.clj
diff options
context:
space:
mode:
Diffstat (limited to 'year2021/day5/part1.clj')
-rw-r--r--year2021/day5/part1.clj75
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)
+ )
+