aboutsummaryrefslogtreecommitdiffstats
path: root/day13
diff options
context:
space:
mode:
authorClyne Sullivan <clyne@bitgloo.com>2021-12-13 11:54:16 -0500
committerClyne Sullivan <clyne@bitgloo.com>2021-12-13 11:54:16 -0500
commitc54de0ebc64a60184f610993b1538006b81c16c3 (patch)
treecde598251053dfaf6fe8c5ec07bd598f33d7b83c /day13
parent55387461c67497e3fca9dd9d675d558745563c14 (diff)
day13: make more concise
Diffstat (limited to 'day13')
-rw-r--r--day13/part1.clj59
-rw-r--r--day13/part2.clj62
2 files changed, 49 insertions, 72 deletions
diff --git a/day13/part1.clj b/day13/part1.clj
index bc7bef6..c3f08d4 100644
--- a/day13/part1.clj
+++ b/day13/part1.clj
@@ -2,40 +2,29 @@
(def input (->> (slurp "./in")
(str/split-lines)
- (split-with not-empty)))
-(def points (->> (first input)
- (map #(str/split % #","))
- (map (partial map read-string))
- (set)))
-(def folds (->> (rest (second input))
- (map #(str/split % #"="))
- (map #(do [(last (first %)) (read-string (second %))]))))
+ (split-with not-empty)
+ ((juxt
+ (fn [lst]
+ (reduce
+ #(conj %1 (mapv read-string (str/split %2 #",")))
+ #{} (first lst)))
+ (fn [lst]
+ (->> (second lst)
+ (drop 1)
+ (map #(-> %
+ (str/split #"=")
+ (update 0 (comp {\x 0 \y 1} last))
+ (update 1 read-string)))
+ (first)
+ ))))))
-(loop [fds (take 1 folds) pts points]
- (if (empty? fds)
- (println (count pts))
- (recur
- (rest fds)
- (let [ins (first fds) chg (second ins)]
- (if (= \x (first ins))
- (reduce
- #(conj %1
- (if (< (first %2) chg)
- %2
- (seq [(- (first %2) (* 2 (- (first %2) chg))) (second %2)])))
- #{}
- pts)
- (reduce
- #(conj %1
- (if (< (second %2) chg)
- %2
- (seq [(first %2) (- (second %2) (* 2 (- (second %2) chg)))])
- ))
- #{}
- pts)
- )
- )
- )
- )
- )
+(defn fold-point [idx chg pt]
+ (cond-> pt (> (get pt idx) chg) (update idx #(- % (* 2 (- % chg))))))
+
+(let [instruction (second input)]
+ (->> (first input)
+ (map (partial fold-point (first instruction) (second instruction)))
+ (distinct)
+ (count)
+ (println)))
diff --git a/day13/part2.clj b/day13/part2.clj
index 89f011d..6db6555 100644
--- a/day13/part2.clj
+++ b/day13/part2.clj
@@ -2,44 +2,32 @@
(def input (->> (slurp "./in")
(str/split-lines)
- (split-with not-empty)))
-(def points (->> (first input)
- (map #(str/split % #","))
- (map (partial map read-string))
- (set)))
-(def folds (->> (rest (second input))
- (map #(str/split % #"="))
- (map #(do [(last (first %)) (read-string (second %))]))))
+ (split-with not-empty)
+ ((juxt
+ (fn [lst]
+ (reduce
+ #(conj %1 (mapv read-string (str/split %2 #",")))
+ #{} (first lst)))
+ (fn [lst]
+ (->> (rest (second lst))
+ (map #(-> %
+ (str/split #"=")
+ (update 0 (comp {\x 0 \y 1} last))
+ (update 1 read-string)))
+ ))))))
(defn print-grid [pts]
- (doseq [p pts] (println (str/join [(first p) "," (second p)])))
- )
+ (doseq [p pts] (println (str/join [(first p) "," (second p)]))))
-(loop [fds folds pts points]
- (if (empty? fds)
- (print-grid pts)
- (recur
- (rest fds)
- (let [ins (first fds) chg (second ins)]
- (if (= \x (first ins))
- (reduce
- #(conj %1
- (if (< (first %2) chg)
- %2
- (seq [(- (first %2) (* 2 (- (first %2) chg))) (second %2)])))
- #{}
- pts)
- (reduce
- #(conj %1
- (if (< (second %2) chg)
- %2
- (seq [(first %2) (- (second %2) (* 2 (- (second %2) chg)))])
- ))
- #{}
- pts)
- )
- )
- )
- )
- )
+(defn fold-point [idx chg pt]
+ (cond-> pt (> (get pt idx) chg) (update idx #(- % (* 2 (- % chg))))))
+
+(print-grid
+ (apply
+ (partial
+ reduce
+ #(let [ins (first %2)]
+ (set (map (partial fold-point (first %2) (second %2)) %1))))
+ input
+ ))