diff options
author | Clyne Sullivan <clyne@bitgloo.com> | 2022-11-30 19:55:31 -0500 |
---|---|---|
committer | Clyne Sullivan <clyne@bitgloo.com> | 2022-11-30 19:55:31 -0500 |
commit | 8d43e37df99f280377bed90284d6ac2428334804 (patch) | |
tree | 3a5042c9af29da52b4bac38fd78b3ccde77a1dbc /day23 | |
parent | 66ed0b9d27850dc653abc8baa75884f3de311bfa (diff) |
move 2021 days to folder; update README
Diffstat (limited to 'day23')
-rw-r--r-- | day23/part1-done-by-hand | 0 | ||||
-rw-r--r-- | day23/part2.clj | 90 |
2 files changed, 0 insertions, 90 deletions
diff --git a/day23/part1-done-by-hand b/day23/part1-done-by-hand deleted file mode 100644 index e69de29..0000000 --- a/day23/part1-done-by-hand +++ /dev/null diff --git a/day23/part2.clj b/day23/part2.clj deleted file mode 100644 index adbefc1..0000000 --- a/day23/part2.clj +++ /dev/null @@ -1,90 +0,0 @@ -(require '[clojure.core.reducers :as r]) - -(def init-field - [nil - nil - (seq [:b :d :d :d]) - nil - (seq [:b :c :b :a]) - nil - (seq [:c :b :a :a]) - nil - (seq [:d :a :c :c]) - nil - nil]) - -(defn do-slot [[field energy] idx] - (let [slot (get field idx)] - (cond - ; Moving value out of a room - (and (seq? slot) - (not (empty? slot)) - (not (every? #(= % ({2 :a 4 :b 6 :c 8 :d} idx)) slot))) - (let [open-slots - (filterv - #(contains? #{0 1 3 5 7 9 10} %) - (concat - (for [i (reverse (range 0 idx)) - :while (or (nil? (get field i)) (seq? (get field i)))] i) - (for [i (range idx (count field)) - :while (or (nil? (get field i)) (seq? (get field i)))] i)))] - (when-not (empty? open-slots) - (map - (fn [os] - [(-> field - (assoc os (first slot)) - (update idx rest)) - (+ energy (* ({:a 1 :b 10 :c 100 :d 1000} (first slot)) - (+ (inc (- 4 (count slot))) (Math/abs (- os idx)))))]) - open-slots))) - ; Moving value into a room - (and (not (seq? slot)) (some? slot)) - (let [our-room ({:a 2 :b 4 :c 6 :d 8} slot)] - (if (every? #(or (nil? (get field %)) (seq? (get field %))) - (range (inc (min our-room idx)) (max our-room idx))) - (let [room (get field our-room)] - (when (or (empty? room) (every? #(= slot %) room)) - [(-> field - (assoc idx nil) - (update our-room conj slot)) - (+ energy (* ({:a 1 :b 10 :c 100 :d 1000} slot) - (+ (Math/abs (- idx our-room)) (- 4 (count room)))))]))))))) - -(defn winner? [[field q s]] - (= field - [nil - nil - (seq [:a :a :a :a]) - nil - (seq [:b :b :b :b]) - nil - (seq [:c :c :c :c]) - nil - (seq [:d :d :d :d]) - nil - nil])) - -(defn do-turns [fields] - (into #{} - (r/fold - r/cat - #(if-let [t (apply do-slot %2)] - (if (seq? t) - (reduce r/append! %1 t) - (r/append! %1 t)) - %1) - (into [] (for [f fields i (range 0 11)] [f i]))))) - -(defn play-games [turns tc] - (println "Games:" (count turns) "Turn:" tc) - (let [new-turns (do-turns turns) - winners (filter winner? new-turns)] - (if (seq winners) - (map second winners) - (recur new-turns (inc tc))))) - -(->> (play-games #{[init-field 0]} 0) - sort - first - ((partial println "Lowest energy:"))) - |