forked from Unicuby/FMSI
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgenPrime.py
52 lines (39 loc) · 929 Bytes
/
genPrime.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# -*- coding: utf-8 -*-
def is_prime(n):
if n == 2 or n == 3: return True
if n < 2 or n % 2 == 0: return False
if n < 9: return True
if n % 3 == 0: return False
r = int(n ** 0.5)
f = 5
while f <= r:
if n % f == 0: return False
if n % (f + 2) == 0: return False
f += 6
return True
def erathosthene(n):
res = [True] * n
res_p = []
res[0] = False
res[1] = False
for i in range(4, n, 2):
res[i] = False
if n < 2:
return []
res_p.append(2)
i = 3
while i * i <= n:
if res[i]:
res_p.append(i)
for j in range(i * i, n, 2 * i):
res[j] = False
i += 1
for j in range(i, n):
if res[j]:
res_p.append(j)
return res_p
if __name__ == "__main__":
table = erathosthene(1000)
count = 0
for n in table:
assert(is_prime(n))