mirror of
https://github.com/Ajetski/advent-of-code.git
synced 2025-09-30 09:23:17 -09:00
format
This commit is contained in:
parent
d98ca00ba5
commit
bed4c55c93
@ -5,42 +5,40 @@
|
||||
|
||||
(def input (get-puzzle-input 1))
|
||||
|
||||
(def numeric-value-map {"one" 1
|
||||
"two" 2
|
||||
"three" 3
|
||||
"four" 4
|
||||
"five" 5
|
||||
"six" 6
|
||||
"seven" 7
|
||||
"eight" 8
|
||||
"nine" 9})
|
||||
;; part 1
|
||||
(->> input
|
||||
(map #(Integer/parseInt
|
||||
(str (re-find #"\d" %)
|
||||
(re-find #"\d" (string/reverse %)))))
|
||||
(reduce +))
|
||||
|
||||
(def numeric-value-map {"one" 1,
|
||||
"two" 2,
|
||||
"three" 3,
|
||||
"four" 4,
|
||||
"five" 5,
|
||||
"six" 6,
|
||||
"seven" 7,
|
||||
"eight" 8,
|
||||
"nine" 9})
|
||||
(defn numeric-value [s]
|
||||
(or (numeric-value-map s) s))
|
||||
|
||||
;; part 1
|
||||
(->> input
|
||||
(map (fn [line]
|
||||
{:first (re-find #"\d" line)
|
||||
:last (re-find #"\d" (string/reverse line))}))
|
||||
(map #(str (:first %) (:last %)))
|
||||
(map #(Integer/parseInt %))
|
||||
(reduce +))
|
||||
(defn generate-regex-pattern [mapping-fn]
|
||||
(->> (keys numeric-value-map)
|
||||
(map mapping-fn)
|
||||
(#(conj % "\\d"))
|
||||
(string/join "|")
|
||||
re-pattern))
|
||||
(def forwards-search-pattern (generate-regex-pattern identity))
|
||||
(def backwards-search-pattern (generate-regex-pattern string/reverse))
|
||||
|
||||
;; part 2
|
||||
(def forawrd-search-regex (->> (conj (keys numeric-value-map) "\\d")
|
||||
(string/join "|")
|
||||
re-pattern))
|
||||
|
||||
(def backwards-search-regex (->> (conj (->> numeric-value-map keys (map string/reverse)) "\\d")
|
||||
(string/join "|")
|
||||
re-pattern))
|
||||
|
||||
(->> input
|
||||
(map (fn [line]
|
||||
(let [f (re-find forawrd-search-regex line)
|
||||
l (string/reverse (re-find backwards-search-regex (string/reverse line)))]
|
||||
(str (numeric-value f) (numeric-value l)))))
|
||||
(map #(Integer/parseInt %))
|
||||
(map #(Integer/parseInt
|
||||
(str (numeric-value (re-find forwards-search-pattern %))
|
||||
(numeric-value (string/reverse
|
||||
(re-find backwards-search-pattern
|
||||
(string/reverse %)))))))
|
||||
(reduce +))
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user