diff options
Diffstat (limited to 'year2021/day9')
-rw-r--r-- | year2021/day9/part1.clj | 21 | ||||
-rw-r--r-- | year2021/day9/part2.clj | 45 |
2 files changed, 66 insertions, 0 deletions
diff --git a/year2021/day9/part1.clj b/year2021/day9/part1.clj new file mode 100644 index 0000000..7bd8e23 --- /dev/null +++ b/year2021/day9/part1.clj @@ -0,0 +1,21 @@ +(def input-map + (->> (slurp "./in") + (clojure.string/split-lines) + (mapv vec) + (mapv (partial mapv #(- (int %) 48))) + )) + +(defn get-adj [y x] + (map (partial get-in input-map) + [[(dec y) x] [(inc y) x] [y (dec x)] [y (inc x)]])) + +(->> (for [y (range 0 (count input-map)) + x (range 0 (count (first input-map))) + :let [height (get-in input-map [y x])] + :when (every? #(or (nil? %) (< height %)) + (get-adj y x))] + (inc height)) + (apply +) + (println) + ) + diff --git a/year2021/day9/part2.clj b/year2021/day9/part2.clj new file mode 100644 index 0000000..3030c4e --- /dev/null +++ b/year2021/day9/part2.clj @@ -0,0 +1,45 @@ +(require '[clojure.set]) + +(defn get-adj + "Gets vector of coords surrounding (x, y)." + [y x] [[(dec y) x] [(inc y) x] [y (dec x)] [y (inc x)]]) + +(defn basin-continues? + "Determines if `b` is a continuation of the basin that includes `a`." + [a b] (and (some? b) (not= b 9) (> b a))) + +(defn basin-bottom? + "Determines if point `p` in `hmap` is the bottom of a basin surrounded by + points `adj`." + [hmap p adj] + (every? + #(let [q (get-in hmap %)] (or (nil? q) (< (get-in hmap p) q))) + adj + )) + +(defn find-basin + "If point `yx` in `hmap` is in a basin (determined using `adj`), return a + list of points in the basin that are above `yx`." + [hmap yx adj] + (let [res (filter #(basin-continues? (get-in hmap yx) + (get-in hmap %)) + adj)] + (apply (partial clojure.set/union res) + (map #(set (find-basin hmap % (apply get-adj %))) res) + ))) + +(->> (slurp "./in") + (clojure.string/split-lines) + (mapv vec) + (mapv (partial mapv #(- (int %) 48))) + (#(for [y (range 0 (count %)) + x (range 0 (count (first %))) + :let [adj (get-adj y x)] + :when (basin-bottom? % [y x] adj)] + (inc (count (find-basin % [y x] adj))))) + (sort >) + (take 3) + (apply *) + (println) + ) + |