Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- 6566
- cmd2
- 백준
- Couldn't read row 0
- pwnable.kr
- 클라우드가 뭐야
- 나이순 정렬
- UNIQUE constraint failed
- 파이썬
- 페니빙
- pwnable
- 액션바 필요없숴
- 블록체인
- col -1 from CursorWindow
- 포너블
- SQLiteConstraintException
- cmd1
- pwable.kr
- python
- tlqkf
- 코틀린
- 쏘큩
- 애너그램 그룹
- Drive-By-Download
- 클라우드란?
- java.lang.IllegalStateException
- Docker
- Make sure the Cursor is initialized correctly before accessing data for it.
- kotlin
- 10814
Archives
- Today
- Total
푸르미르
[python]1929.소수 구하기 본문
M이상 N이하의 소수를 모두 출력하는 프로그램을 작성하는 문제인데 솔직히 알고리즘 시간에 배워서 별 생각이 없었다.
아무생각없이 풀다가 시간초과났다.
이럴거면 문제에 일반적으로 소수를 구하는 알고리즘을 구현하다가는 시간초과딱밤을 맞게 될거라고 말좀 해주던가.
이게 시간초과 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
m,n = map(int, input().split()) #정수 입력
for i in range(m, n+1):
if i==1:
continue
if i==2:
print(i)
else:
for j in range(2, i):
if i%j==0:
break
if j==i-1:
print(i)
|
cs |
아무생각없이 해당 숫자까지 나누기로 구하다가는 큰코다친다.
다른 블로그 글 봤는데 에라토스테네스 체?를 사용하던데 그러지 않아도 된다, 이 문제에선.
해당 숫자가 소수인지를 판별하는 방법은 2부터 그 숫자까지 나누기를 계속해서 나머지가 0인 적이 없었던 숫자를 소수라고 판단하는 방법도 있지만 해당 숫자의 제곱근까지 나누기를 해서 나머지가 0인적이 있는지 없는지해서 소수를 판별할 수도 있다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
import math
def primeop(num):
if num==1:
return False
if num==2:
return True
else:
for j in range(2, int(math.sqrt(num))+1):
if num%j==0:
return False
return True
m,n = map(int, input().split()) #정수 입력
for i in range(m, n+1):
if primeop(i):
print(i)
|
cs |
'Baekjoon Online Judge' 카테고리의 다른 글
[python]9020.골드바흐의 추측 (2) | 2021.01.21 |
---|---|
[python]4948.베르트랑 공준 (0) | 2021.01.21 |
[python]10757.큰 수 A+B (0) | 2021.01.15 |
[python]10250.ACM 호텔 (2) | 2021.01.12 |
[python]2869.달팽이는 올라가고 싶다. (2) | 2021.01.10 |