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.2.1.98 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.97 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.96 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.95 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.94 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.93 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.92 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.91 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.90 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.89 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.88 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.87 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.86 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.85 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.84 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.83 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.82 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.81 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.80 tracks/python/exercises/nth-prime/example.py
trackler-2.2.1.79 tracks/python/exercises/nth-prime/example.py