-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathproblem_010.py
More file actions
46 lines (36 loc) · 931 Bytes
/
problem_010.py
File metadata and controls
46 lines (36 loc) · 931 Bytes
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
# https://projecteuler.net/problem=10
# Calculate sum of all prime numbers smaller than 2,000,000
import math
# Get all primes number under 2 millions
LIMIT = 2000000
# Function to check whether a number is a prime number
def isPrime(number):
if number > 1:
if number == 2:
return True
if number % 2 == 0:
return False
for currentNumber in range(3, int(math.sqrt(number) + 1), 2):
if number % currentNumber == 0:
return False
return True
return False
# A generator to keep counting and checking for whether a number is a prime number
def getPrimes(startNumber):
while True:
if isPrime(startNumber):
yield startNumber
startNumber += 1
# Use the getPrimes() generator to count sum of all prime numbers
def sumPrimes():
total = 2
for number in getPrimes(3):
if number < LIMIT:
total += number
else:
print total
return
def main():
sumPrimes()
if __name__ == "__main__":
main()