Python/maths/prime_sieve_eratosthenes.py

42 lines
801 B
Python
Raw Normal View History

'''
Sieve of Eratosthenes
Input : n =10
Output : 2 3 5 7
Input : n = 20
Output: 2 3 5 7 11 13 17 19
you can read in detail about this at
https://en.wikipedia.org/wiki/Sieve_of_Eratosthenes
'''
def prime_sieve_eratosthenes(num):
"""
print the prime numbers upto n
>>> prime_sieve_eratosthenes(10)
2 3 5 7
>>> prime_sieve_eratosthenes(20)
2 3 5 7 11 13 17 19
"""
primes = [True for i in range(num + 1)]
p = 2
while p * p <= num:
if primes[p] == True:
for i in range(p*p, num+1, p):
primes[i] = False
p+=1
for prime in range(2, num+1):
if primes[prime]:
print(prime, end=" ")
if __name__ == "__main__":
num = int(input())
prime_sieve_eratosthenes(num)