하루살이 개발자

[BaekJoon 4948번] 베르트랑 공준(Python) 본문

코딩테스트

[BaekJoon 4948번] 베르트랑 공준(Python)

하루살이 2022. 2. 20. 12:58

베르트랑 공준 문제입니다.

 

문제링크: https://www.acmicpc.net/problem/4948

 

4948번: 베르트랑 공준

베르트랑 공준은 임의의 자연수 n에 대하여, n보다 크고, 2n보다 작거나 같은 소수는 적어도 하나 존재한다는 내용을 담고 있다. 이 명제는 조제프 베르트랑이 1845년에 추측했고, 파프누티 체비쇼

www.acmicpc.net

 

풀이

소수 찾는 알고리즘인 에라토스테네스의 채 알고리즘 이용

 

 

Code

# 소수 찾는 알고리즘(에라토스테네스의 체)
def prime_list(n):
    # 에라토스테네스의 체 초기화: n개 요소에 True 설정(소수로 간주)
    sieve = [True] * n

    m = int(n ** 0.5)
    for i in range(2, m + 1):
        if sieve[i] == True:           # i가 소수인 경우
            for j in range(i+i, n, i): # i이후 i의 배수들을 False 판정
                sieve[j] = False

    # 소수 목록 산출
    return [i for i in range(2, n) if sieve[i] == True]

while True:
    count = 0
    result = []
    n = int(input())

    if n == 0:
        break

    # 2* n 까지 소수만 구하기
    li = prime_list(2 * n+ 1)
    for i in li:
        if i > n:
            result.append(i)

    print(len(result))