aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/core.clj12
-rw-r--r--challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t1.clj19
-rw-r--r--challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t2.clj27
-rw-r--r--challenge-115/tyler-wardhaugh/clojure/test/tw/weekly/c115_test.clj10
4 files changed, 68 insertions, 0 deletions
diff --git a/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/core.clj b/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/core.clj
new file mode 100644
index 0000000000..9d83092eaf
--- /dev/null
+++ b/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/core.clj
@@ -0,0 +1,12 @@
+(ns tw.weekly.c115.core
+ (:require [tw.weekly.c115.t1 :as t1])
+ (:require [tw.weekly.c115.t2 :as t2])
+ (:gen-class))
+
+(defn -main
+ "Run all tasks"
+ [& _]
+ (println "Task #1:")
+ (t1/-main)
+ (println "\nTask #2:")
+ (t2/-main))
diff --git a/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t1.clj b/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t1.clj
new file mode 100644
index 0000000000..8abc631b84
--- /dev/null
+++ b/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t1.clj
@@ -0,0 +1,19 @@
+(ns tw.weekly.c115.t1
+ (:require [clojure.edn :as edn]
+ [clojure.string :as str]))
+
+;;;
+; Task description for TASK #1 › String Chain
+;;;
+(def DEFAULT-INPUT ["abc" "dea" "cd"])
+
+(defn string-chain
+ ""
+ [coll])
+
+(defn -main
+ "Run Task 1 with a given input N, defaulting to the first example from the
+ task description."
+ [& args]
+ (let [S (or (some->> args (map edn/read-string)) DEFAULT-INPUT)]
+ (println (string-chain S))))
diff --git a/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t2.clj b/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t2.clj
new file mode 100644
index 0000000000..f401262044
--- /dev/null
+++ b/challenge-115/tyler-wardhaugh/clojure/src/tw/weekly/c115/t2.clj
@@ -0,0 +1,27 @@
+(ns tw.weekly.c115.t2
+ (:require [clojure.edn :as edn]))
+
+;;;
+; Task description for TASK #2 › Largest Multiple
+;;;
+(def DEFAULT-INPUT [1 0 2 6])
+
+(defn largest-multiple
+ "Determine the largest mulitple that can be formed using coll"
+ [coll]
+ (let [min-even (->> coll (filter even?) (reduce min))
+ freqs (-> coll frequencies (update min-even dec))
+ remaining (into [] (mapcat (fn [[num x]] (repeat x num))) freqs)]
+ (->> remaining
+ sort
+ (concat [min-even])
+ reverse
+ (reduce str "")
+ (Integer/parseInt))))
+
+(defn -main
+ "Run Task 2 with a given input N, defaulting to the first example from the
+ task description."
+ [& args]
+ (let [N (or (some->> args (map edn/read-string)) DEFAULT-INPUT)]
+ (println (largest-multiple N))))
diff --git a/challenge-115/tyler-wardhaugh/clojure/test/tw/weekly/c115_test.clj b/challenge-115/tyler-wardhaugh/clojure/test/tw/weekly/c115_test.clj
new file mode 100644
index 0000000000..18141065d6
--- /dev/null
+++ b/challenge-115/tyler-wardhaugh/clojure/test/tw/weekly/c115_test.clj
@@ -0,0 +1,10 @@
+(ns tw.weekly.c115-test
+ (:require [clojure.test :refer [deftest is testing]]
+ #_[tw.weekly.c115.t1 :refer []]
+ [tw.weekly.c115.t2 :refer [largest-multiple]]))
+
+(deftest task-2
+ (testing "Task 2, Largest Multiple"
+ (is (= 6210 (largest-multiple [1 0 2 6])))
+ (is (= 8412 (largest-multiple [1 4 2 8])))
+ (is (= 7614 (largest-multiple [4 1 7 6])))))