Sha256: 65c2ae7dc3a0efc6130fb25b0e179e7b3530f8133979771148f07d0c685d2a36

Contents?: true

Size: 832 Bytes

Versions: 289

Compression:

Stored size: 832 Bytes

Contents

(ns nth-prime)

(defn sqrt
  "Wrapper around java's sqrt method."
  [number]
  (int (Math/ceil (Math/sqrt number))))

(defn divides?
  "Helper function to decide if a number is evenly divided by divisor."
  [number divisor]
  (zero? (mod number divisor)))

(defn- prime-by-trial-division?
  "Simple trial division prime check."
  [number]
  (empty? (for [n (range 3 (inc (sqrt number)) 2) :when (divides? number n)] n)))

(defn prime? [number]
  (or (= 2 number)
      (and (odd? number) (prime-by-trial-division? number))))

(defn next-prime [start]
  (loop [n (inc start)]
    (if (prime? n)
      n
      (recur (inc n)))))

(def primes (iterate next-prime 1))

(defn nth-prime [index]
  (when-not (pos? index)
    (throw (IllegalArgumentException. "nth-prime expects a positive integer for an argument")))
  (nth primes index))

Version data entries

289 entries across 289 versions & 1 rubygems

Version Path
trackler-2.2.1.98 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.97 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.96 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.95 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.94 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.93 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.92 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.91 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.90 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.89 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.88 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.87 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.86 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.85 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.84 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.83 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.82 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.81 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.80 tracks/clojure/exercises/nth-prime/src/example.clj
trackler-2.2.1.79 tracks/clojure/exercises/nth-prime/src/example.clj