[Python] 자연수 n 이하의 소수 구하기
                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))
'프로그래밍 > 기타' 카테고리의 다른 글
| [Python3] Merge Sort (병합 정렬) (0) | 2018.07.14 | 
|---|---|
| Flask에서 No-Cache 헤더 설정 (0) | 2018.05.29 | 
| [Python3] a^3 + b^3 = c^3 + d^3 을 만족하는 자연수 1000 이하의 조합 (0) | 2018.05.24 | 
| [Python] CentOS 리눅스 Python 3 설치 (1) | 2017.05.07 | 
| [Python] 로또 번호 생성 (4) | 2017.05.07 | 
| [java] 복잡도를 만족하는 랜덤 패스워드 생성 (11) | 2011.12.26 | 
| [java] 랜덤 패스워드 생성 (19) | 2011.05.21 | 
| VisualSVN 서버로 Subversion 서버 구동하기 (9) | 2011.03.09 | 
최근에 달린 댓글 최근에 달린 댓글