늒네 기록

[PE] Project Euler 37 본문

알골 공부 기록/Project Euler

[PE] Project Euler 37

jaeha lee 2020. 10. 4. 02:16

프로젝트 오일러 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<2return False
    for i in range(2,int(n**0.5)+1):
        if n%i==0return 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
 
= []
= 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