일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- spring security
- codility
- javascript
- 소수
- 최단경로
- Dijkstra
- Spring
- HTTP
- java
- beandefinitionstoreexception
- 2981
- algorithm
- Greedy
- counting elements
- Python
- brute force
- error
- BFS
- 파이썬
- 알고리즘
- 2018 KAKAO BLIND RECRUITMENT
- 프로그래머스
- 탐욕법
- applicationeventpublisher
- springboot
- 코딩테스트
- API
- 문자열
- 라이브템플릿
- 백준
Archives
- Today
- Total
Altiora Petamus
베르트랑 공준 본문
문제
베르트랑 공준은 임의의 자연수 n에 대하여, n보다 크고, 2n보다 작거나 같은 소수는 적어도 하나 존재한다는 내용을 담고 있다.
이 명제는 조제프 베르트랑이 1845년에 추측했고, 파프누티 체비쇼프가 1850년에 증명했다.
예를 들어, 10보다 크고, 20보다 작거나 같은 소수는 4개가 있다. (11, 13, 17, 19) 또, 14보다 크고, 28보다 작거나 같은 소수는 3개가 있다. (17,19, 23)
자연수 n이 주어졌을 때, n보다 크고, 2n보다 작거나 같은 소수의 개수를 구하는 프로그램을 작성하시오.
🤔생각해보기
기본수학 문제에 자주 나오고 있는 소수 찾기의 응용이다.
범위만 추가된 것이니 소수를 좀 찾아봤다면(?) 조금만 생각해보면 해결 할 수 있다.
성공코드
import math
import sys
while True:
n = int(sys.stdin.readline())
if n == 0:
break
prime = []
for num in range(n + 1, 2 * n + 1):
is_prime = True
if num == 1:
continue
for i in range(2, int(math.sqrt(num)) + 1):
if num % i == 0:
is_prime = False
break
if is_prime:
prime.append(num)
print(len(prime))
'1day-1algorithm' 카테고리의 다른 글
네 번째 점 (0) | 2021.06.16 |
---|---|
수 찾기 (0) | 2021.06.15 |
DFS와 BFS (0) | 2021.06.11 |
binary gap (0) | 2021.06.10 |
소수 (0) | 2021.06.07 |