aboutsummaryrefslogtreecommitdiffstats
path: root/day20
diff options
context:
space:
mode:
authorClyne Sullivan <clyne@bitgloo.com>2021-12-20 12:24:12 -0500
committerClyne Sullivan <clyne@bitgloo.com>2021-12-20 12:24:12 -0500
commitaa5ca3ab7ce773b321821e1b9f3a99344725dee2 (patch)
tree81eb14313aeaf8be9e47acbb6ec172362ffcf099 /day20
parent92f81f19259b3d69f78334b25b746e955d558c70 (diff)
day20: forgot to put into folder
Diffstat (limited to 'day20')
-rw-r--r--day20/partboth.clj44
1 files changed, 44 insertions, 0 deletions
diff --git a/day20/partboth.clj b/day20/partboth.clj
new file mode 100644
index 0000000..4e460ca
--- /dev/null
+++ b/day20/partboth.clj
@@ -0,0 +1,44 @@
+(require '[clojure.string :as str])
+
+(defn pad-input-map [in-map pad-val]
+ (let [pad-row (repeat (+ 4 (count (first in-map))) pad-val)
+ pad-side (repeat 2 pad-val)]
+ (mapv vec
+ (concat
+ [pad-row pad-row]
+ (mapv #(concat pad-side % pad-side) in-map)
+ [pad-row pad-row]))))
+
+(defn get-number [in-map y x]
+ (concat (subvec (get in-map (dec y)) (dec x) (+ 2 x))
+ (subvec (get in-map y) (dec x) (+ 2 x))
+ (subvec (get in-map (inc y)) (dec x) (+ 2 x))))
+
+(defn get-new-pixel [enhance-algo in-map y x]
+ (->> (get-number in-map y x)
+ str/join
+ (#(Integer/parseInt % 2))
+ (get enhance-algo)
+ {\. 0 \# 1}))
+
+(defn build-output-number-map [enhance-algo in-map]
+ (let [pad-val (if (= \# (first enhance-algo)) (first (first in-map)) 0)
+ padded-in-map (pad-input-map in-map pad-val)]
+ (for [y (range 1 (dec (count padded-in-map)))]
+ (for [x (range 1 (dec (count (first padded-in-map))))]
+ (get-new-pixel enhance-algo padded-in-map y x)
+ ))))
+
+(defn count-lit-pixels [in-map]
+ ((frequencies (flatten in-map)) 1))
+
+(let [[enhance-algo in-map]
+ (->> (slurp "./in")
+ str/split-lines
+ ((juxt
+ first
+ (comp (partial mapv #(mapv {\. 0 \# 1} %))
+ (partial drop 2)))))
+ image-output (iterate (partial build-output-number-map enhance-algo) in-map)]
+ (println (count-lit-pixels (nth image-output 50))))
+