일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- convention
- mysql
- 자료구조
- lower_case_table_names
- datetime
- 큰 수 나누기
- 소수
- Dictionary
- ceil
- python
- timestamp
- 세그먼트 트리
- FOREIGN KEY
- 2557
- 에라토스테네스의 체
- itertools
- 리스트 컴프리헨션
- list comprehension
- SUM()
- SUM
- project euler
- 파이썬
- floor
- Codeforces
- BOJ
- 네이밍
- 외래키
- flask
- 딕셔너리
- enumerate
Archives
- Today
- Total
늒네 기록
[PE] Project Euler 41 본문
프로젝트 오일러 41번은 어떤 소수 n이 x자리 수일때, 1부터 x까지의 숫자가 모두 등장하면 이를 pandigital prime이라고 부른다고 한다면, 이러한 조건을 만족하는 제일 큰 소수 p를 구하라는 문제다.
pandigital 조건이 붙어있으므로 p는 아무리 커도 9자리여야 하는데, 1~9가 모두 등장하는 9자리 수는 각 자릿수를 다 더하면 45이므로 3의 배수가 되어 소수가 될 수 없다. 즉, p는 아무리 커봐야 8자리인 것이다.
문제에 나이브하게 접근하여 8자리 소수들을 전부 구한 뒤, 큰 소수부터 시작하여 위의 조건을 만족하는지 체크하는 루프를 도는 방식으로 문제를 풀었다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
n=10**8
p = [True for i in range(n)]
pl = []
cnt=0
for i in range(2,n):
if p[i]:
pl.append(i)
for j in range(i,n,i): p[j]=False
cnt+=1
if cnt==10000:
print(i)
cnt=0
for x in reversed(pl):
pp = str(x)
if set(pp) == set([str(i) for i in range(1,len(pp)+1)]):
print(f'solution:{pp}')
break
|
cs |
이렇게 풀어도 대략 1분 30초 정도에 계산이 끝났다.
반응형
'알골 공부 기록 > Project Euler' 카테고리의 다른 글
[PE] Project Euler 37 (0) | 2020.10.04 |
---|---|
[PE] Project Euler 27 (0) | 2020.10.04 |
[PE] Project Euler 72 (0) | 2020.10.03 |
[PE] Project Euler 57 (0) | 2020.10.03 |
[PE] Project Euler 55 (0) | 2020.10.03 |
Comments