day7: improved
parent
65df6869e9
commit
ec649250aa
@ -1,26 +1,22 @@
|
||||
(def input
|
||||
(->> (slurp "./in") ; "16,1,2,0,4,2,7,1,2,14"
|
||||
(#(clojure.string/split % #","))
|
||||
(map read-string)
|
||||
)
|
||||
)
|
||||
|
||||
(defn median [lst]
|
||||
(let [cnt (count lst)
|
||||
hlf (quot cnt 2)
|
||||
srt (sort lst)]
|
||||
(if (odd? cnt)
|
||||
(nth srt hlf)
|
||||
(quot (+ (nth srt hlf) (nth srt (dec hlf))) 2)
|
||||
(cond->> (nth srt hlf)
|
||||
(even? cnt)
|
||||
(+ (nth srt (dec hlf)))
|
||||
:true
|
||||
(#(quot % 2))
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
(println
|
||||
(->> input
|
||||
(map (partial - (median input)))
|
||||
(map #(if (neg? %) (- %) %))
|
||||
(->> (slurp "./in") ; "16,1,2,0,4,2,7,1,2,14"
|
||||
(#(clojure.string/split % #","))
|
||||
(map read-string)
|
||||
(#(map (partial - (median %)) %))
|
||||
(map #(Math/abs %))
|
||||
(apply +)
|
||||
)
|
||||
(println)
|
||||
)
|
||||
|
||||
|
@ -1,23 +1,23 @@
|
||||
(def input
|
||||
(->> (slurp "./in") ;"16,1,2,0,4,2,7,1,2,14"
|
||||
(#(clojure.string/split % #","))
|
||||
(map read-string)
|
||||
(defn calc-fuel [lst pos]
|
||||
(->> lst
|
||||
(map
|
||||
(comp
|
||||
#(/ (* % (inc %)) 2)
|
||||
#(Math/abs %)
|
||||
(partial - pos)
|
||||
)
|
||||
)
|
||||
|
||||
(defn mean [lst]
|
||||
(quot (apply + lst) (count lst))
|
||||
)
|
||||
|
||||
(defn calc-fuel [lst meen]
|
||||
(->> input
|
||||
(map (partial - meen))
|
||||
(map #(if (neg? %) (- %) %))
|
||||
(map #(apply + (range 1 (inc %))))
|
||||
(apply +)
|
||||
)
|
||||
)
|
||||
|
||||
(println (min (calc-fuel input (mean input))
|
||||
(calc-fuel input (inc (mean input)))))
|
||||
(let [input (->> (slurp "./in") ;"16,1,2,0,4,2,7,1,2,14"
|
||||
(#(clojure.string/split % #","))
|
||||
(map read-string)
|
||||
)
|
||||
mean (quot (apply + input) (count input))
|
||||
]
|
||||
(println (min (calc-fuel input mean)
|
||||
(calc-fuel input (inc mean))))
|
||||
)
|
||||
|
||||
|
Loading…
Reference in New Issue