백준 4938 파이썬 에라토스테네스의 체

2024. 4. 27. 08:11코딩 도구/백준 (단계별)

반응형

백준 4938 - 베르트랑 공준

문제

https://www.acmicpc.net/problem/4948

 

4948번: 베르트랑 공준

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

www.acmicpc.net

4938정

답안 코드 :

while True:
    n = int(input())
    if n == 0:
        break
    
    # 에라토스테네스의 체를 활용한 소수 판별
    is_prime = [True] * (2 * n + 1)
    is_prime[0] = is_prime[1] = False  # 0과 1은 소수가 아님

    for i in range(2, int((2 * n) ** 0.5) + 1):
        if is_prime[i]:
            for j in range(i * i, 2 * n + 1, i):
                is_prime[j] = False

    # 소수 개수 세기
    count = sum(1 for num in range(n + 1, 2 * n + 1) if is_prime[num])

    print(count)

백준 / 문제 / 단계별로 풀어보기 / 15단계 약수, 배수와 소수 2

생각 :

# 에라토스테네스의 체
# 이 알고리즘은 고대 그리스의 수학자 에라토스테네스에 의해 고안되었습니다.

# 알고리즘의 주요 아이디어는 다음과 같습니다:

# 2부터 시작하여, 현재까지 찾아낸 소수의 배수를 모두 제거한다.
# 남아 있는 가장 작은 수가 다음 소수이므로, 이를 찾아내고 해당 소수의 배수를 모두 제거한다.
# 반복하여 소수를 찾아내고, 남은 수가 없을 때까지 반복한다.

반응형