Sha256: 3b0799fbbf247ca7f841ad150adecf5d1a418a896ef50c977b03a4b3246dab33

Contents?: true

Size: 664 Bytes

Versions: 258

Compression:

Stored size: 664 Bytes

Contents

from itertools import count
from math import sqrt


def nth_prime(n):
    if n < 1:
        raise ValueError('The parameter `n` has to be a positive number.')

    known = []
    candidates = prime_candidates()

    def is_prime(m):
        sqrt_m = sqrt(m)
        for k in known:
            if k > sqrt_m:
                return True
            elif m % k == 0:
                return False
        return True

    while len(known) < n:
        x = next(candidates)
        if is_prime(x):
            known.append(x)

    return known[n - 1]


def prime_candidates():
    yield 2
    yield 3
    for n in count(6, 6):
        yield n - 1
        yield n + 1

Version data entries

258 entries across 258 versions & 1 rubygems

Version Path
trackler-2.1.0.20 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.19 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.18 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.17 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.16 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.15 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.14 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.13 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.12 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.11 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.10 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.9 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.8 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.7 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.6 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.5 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.4 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.3 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.2 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.1 tracks/python/exercises/nth-prime/example.py