프로그래밍/기타
[Python] 자연수 n 이하의 소수 구하기
snoopybox
2017. 5. 7. 03:05
자연수 n 이하의 소수를 구하는 문제이다.
임의의 자연수 n이 소수인지 아닌지 판별하기 위해서는 아래 조건만 확인하면 된다.
n을 n^0.5 이하의 소수로 나누었을 때 떨어지지 않아야 함
왜 n보다 작은 소수 전체가 아닌 n^0.5 이하의 소수만 테스트해봐도 되는 것일까?
그 이유는 다음과 같다.
만약 n이 n^0.5 초과의 m이라는 수로 나누어 떨어진다면
n = m * p 로 표현될 수 있다.
그렇다면 p는 반드시 n^0.5 미만의 수가 된다.
따라서 n이 소수인지 아닌지 판별할 때 m으로 나눠보기 전에 이미 그보다 작은 p로 나눠봤을 것이고
따라서 소수가 아니라는 판단을 했을 것이기 때문에 m까지 도달할 일이 없다.
#!/usr/bin/env python3
def getPrimeList(num):
primes = []
if num < 2:
return primes
for i in range(2, num+1):
isPrime = True
for j in primes:
if i % j == 0:
isPrime = False
break
elif j > i**0.5:
break
if isPrime:
primes.append(i)
return primes
# 1000 이하의 소수를 출력해보자
if __name__ == '__main__':
print(getPrimeList(1000))