Sha256: 35aa5896f3d83521f79d56842c3f9af201fd45a0444a4288de997e73c94eaba3

Contents?: true

Size: 778 Bytes

Versions: 396

Compression:

Stored size: 778 Bytes

Contents

(ns minesweeper
  (:require [clojure.pprint :refer [cl-format]]
            [clojure.string :refer [split-lines]]))

(defn- windows [field]
  (->> field
       (map #(partition 3 1 `(nil ~@% nil)))
       (apply map #(partition 3 1 `(nil ~@%& nil)))
       (apply map vector)))

(defn- count-mines-around [[[a b c]
                            [d e f]
                            [g h i]]]
  (if-let [mines-count (and (= \space e)
                            (count (filter #{\*} [a b c d f g h i])))]
    (if (zero? mines-count)
      \space
      mines-count)
    e))

(defn draw [field]
  (if (empty? field) ""
      (->> field
           split-lines
           windows
           (map (fn [line] (map count-mines-around line)))
           (cl-format nil "~{~{~a~}~^~%~}"))))

Version data entries

396 entries across 396 versions & 1 rubygems

Version Path
trackler-2.2.1.119 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.118 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.117 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.116 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.115 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.114 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.113 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.111 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.110 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.109 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.108 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.107 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.106 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.105 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.104 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.103 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.102 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.101 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.100 tracks/clojure/exercises/minesweeper/src/example.clj
trackler-2.2.1.99 tracks/clojure/exercises/minesweeper/src/example.clj