/
prime_gen.py
88 lines (84 loc) · 2.14 KB
/
prime_gen.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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import sys
sys.dont_write_bytecode = True
import math
candidates = ['a',
'b',
'c',
'd',
'e',
'f',
'g',
'h',
'i',
'j',
'k',
'l',
'm',
'n',
'o',
'p',
'q',
'r',
's',
't',
'u',
'v',
'w',
'x',
'y',
'z',
'0',
'1',
'2',
'3',
'4',
'5',
'6',
'7',
'8',
'9',
'~',
'!',
'@',
'#',
'$',
'%',
'^',
'&',
'*',
'(',
')',
'-',
'_',
'+',
'=',
'[',
']',
'{',
'}',
'\\',
'/',
':',
'.',
',',
'<',
'>',
'?',
'|']
def is_prime(n):
if n % 2 == 0 and n > 2:
return False
for i in range(3, int(math.sqrt(n)) + 1, 2):
if n % i == 0:
return False
return True
def gen_4n3():
k = []
n = 1000
for a in range(1, n):
pc = is_prime(((4*a) + 3))
if pc:
k.append(((4*a) + 3))
if len(k) == 65:
break
return dict([(val, prime) for val, prime in zip(candidates, k)])