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.41 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.40 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.39 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.38 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.37 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.36 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.34 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.33 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.32 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.31 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.30 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.29 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.28 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.27 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.26 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.25 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.24 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.23 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.22 tracks/python/exercises/nth-prime/example.py
trackler-2.1.0.21 tracks/python/exercises/nth-prime/example.py