일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 세그먼트 트리
- project euler
- Dictionary
- datetime
- BOJ
- 딕셔너리
- convention
- 리스트 컴프리헨션
- floor
- 에라토스테네스의 체
- 2557
- itertools
- mysql
- 소수
- FOREIGN KEY
- ceil
- 파이썬
- 네이밍
- SUM()
- enumerate
- 외래키
- python
- timestamp
- 큰 수 나누기
- 자료구조
- Codeforces
- lower_case_table_names
- SUM
- flask
- list comprehension
Archives
- Today
- Total
늒네 기록
[PE] Project Euler 37 본문
프로젝트 오일러 37번도 나이브하게 덤볐는데도 풀린 문제. 이 문제는 어떤 숫자 p가 주어졌을때, 이 숫자 자체도 소수이면서 좌측부터 숫자를 하나씩 제거하면서 만드는 숫자들도 전부 소수, 우측부터 숫자를 하나씩 제거하면서 만드는 숫자들도 전부 소수인 숫자를 truncatable prime이라고 정의하고, 딱 11개 존재하는 이 숫자들을 전부 찾아서 더하라는 문제다.
별 다른 테크닉 없이 10부터 시작하여 1씩 더해가면서 해당 숫자가 조건을 만족하면 리스트에 더하는 루프를 돌고, 리스트 크기가 11이 되면 루프를 빠져나오는 식으로 구현했다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
def p_test(n):
if n<2: return False
for i in range(2,int(n**0.5)+1):
if n%i==0: return False
return True
def tp_test(n):
nn = str(n)
for i in range(len(nn)):
if not p_test(int(nn[i:])):
return False
if not p_test(int(nn[:i+1])):
return False
return True
l = []
x = 10
while len(l)<11:
if tp_test(x):
print(x)
l.append(x)
x+=1
print(sum(l))
|
cs |
이렇게 짜도 10초 미만에 답을 구할 수 있다.
반응형
'알골 공부 기록 > Project Euler' 카테고리의 다른 글
[PE] Project Euler 41 (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